亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Spring-Data-JPA整合MySQL和配置的方法

2024-07-13 10:17:37
字體:
來源:轉載
供稿:網友

一、簡介

(1)、MySQL是一個關系型數據庫系統,是如今互聯網公司最常用的數據庫和最廣泛的數據庫。為服務端數據庫,能承受高并發的訪問量。

(2)、Spring-Data-Jpa是在JPA規范下提供的Repository層的實現,可以使用不同的實現框架如Hibernate、OpenJpa等框架進行開發,這樣可以使得Repository變得簡單,也解決了其與業務層的耦合性。

本此學習我們使用MySQL+Spring-Data-Jpa搭建,Jpa實現方式使用Hibernate,數據庫連接池使用dbcp進行連接

二、項目搭建

 1、引入MySQL以及Jpa相關依賴:

<!-- spring-jdbc相關依賴 --><dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId></dependency><!-- 用于連接mysql的相關依賴 --><dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId></dependency><!-- jpa相關的依賴 包含spring-data-jpa、spring-orm 和 Hibernate 來支持 JPA --><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId></dependency> 

需要引入三個依賴,jdbc為spring整合MySQL需要的依賴,第二個為MySQL的數據庫驅動依賴,第三個為Spring-Data-Jpa相關的依賴包含:

Spring,Data,JPA整合MySQL,JPA,MySQL

其中其包含AOP、jdbc、Spring-ORM、事務Transaction-api和Hibernate等依賴來支持。所以Jpa默認為使用Hibernate進行實現。

2 、配置文件配置:

配置文件我們選擇.yml格式文件進行配置,并且使用dpcp2配置連接池參數:

1)項目相關配置:

server: #配置端口號 port: 8088spring: application:  #配置服務名稱 name: cms-dept

此處為配置配置服務器開啟的相關信息,主要為配置服務器名稱和端口

2)MySQL相關配置

spring:#數據源和jpa配置 datasource: #數據庫相關的配置url -SSL連接設置為false url: jdbc:mysql://localhost:3306/crm?characterEncoding=utf8&useSSL=false #配置用戶名 username: *** #配置密碼 password: ***

此處為數據庫相關的一些配置,主要為配置數據庫url、賬號和密碼。url后配置信息為連接MySQL的編碼格式和是否啟用SSL加密。

3)DBCP相關配置

spring: #下面為連接池相關配置 dbcp2:  #初始化連接池大小  initial-size: 10  #陪住最小連接池數  min-idle: 10    #配置最大連接池數  max-idle: 30  #配置獲取超時連接的等待時間  max-wait-millis: 30000  #配置多長時間進行一次檢測,檢測需要關閉的數據庫連接  time-between-eviction-runs-millis: 200000  #配置連接在連接池的最小生存時間  remove-abandoned-on-maintenance: 200000

主要配置為一些連接池的信息,配置詳情如上注釋所示。

4)Spring-Data-Jpa依據iHibernata相關配置

spring:  jpa: #配置數據庫類型 database: MYSQL #配置是否打印sql show-sql: true #Hibernate相關配置 hibernate:  #配置級聯等級   ddl-auto: update  naming:  #命名策略  strategy: org.hibernate.cfg.ImprovedNamingStrategy properties:  hibernate:   dialect: org.hibernate.dialect.MySQL5Dialect

配置依次為連接數據庫類型,是否打印Sql和hIbernate級聯方式,有以下幾種:

1)、validate- 加載hibernate時,驗證創建數據庫表結構。

2)、create- 每次加載hibernate,重新創建數據庫表結構,這就是導致數據庫表數據丟失的原因。

3)、create-drop 加載hibernate時創建,退出是刪除表結構。

4)、update-級聯更新 加載hibernate自動更新數據庫結構。

我們在此選擇級聯更新,在原有表基礎上進行迭代。

命名策略有以下兩種:

1)、 org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy 遇到大寫字母 加”_”的命名。

2)、 org.hibernate.cfg.ImprovedNamingStrategy   無修改命名 。

3 、相關類進行配置:

配置類需要配置與氣動類的平級目錄或者子目錄下,才能被配置成功,此處我們使用Java類配置取代xml方式進行配置:

/** * @功能描述:用于MySQL相關配置的類 * @author Administrator *///下面此行用來排序的注解接口,用于處理加載優先級的問題,擁有兩個枚舉變量 @Order(Ordered.HIGHEST_PRECEDENCE)//下面此行代表此類為配置類@Configuration //下面此行代表此類開啟事務管理@EnableTransactionManagement(proxyTargetClass = true)//也可以定義為類 如DeptRepository.class 也可以定義過濾器 includeFilters={ @ComponentScan.Filter(type=FilterType.ANNOTATION,value=Service.class)} @EnableJpaRepositories(basePackages="com.hzt.**.repository")public class MySQLConfig {  @Bean PersistenceExceptionTranslationPostProcessor persistenceExceptionTranslationPostProcessor() {  return new PersistenceExceptionTranslationPostProcessor(); }}

1)、@Order注解,用于配置類的加載優先級別,其擁有兩個枚舉變量:
   Ordered.HIGHEST_PRECEDENCE- Integer.MIN_VALUE -最小值,擁有最高優先級
   Ordered.LOWEST_PRECEDENCE -Integer.MAX_VALUE -最大值,擁有最低優先級

2)、@Configuration 注解,代表此類為配置類

3)、@EnableTransactionManagement 用于MySQL的事務管理 proxyTargetClass= true代表開啟類的事務管理

4)、@EnableJpaRepositories 用于配置事務,此處以cgnl表達式表示路徑,也可以定義為具體的類,例如DeptRepository.class
  其子元素includeFilters可以定義事務攔截器,如includeFilters={ @ComponentScan.Filter(type=FilterType.ANNOTATION,value=Service.class)}

4 、ORM映射Java類相關代碼:

1)數據庫表結構

Spring,Data,JPA整合MySQL,JPA,MySQL
  

2)實體類映射

@Entity //代表此類為一個表的映射entity類@Table(name="tbl_dept") //設置對應的表名public class Dept implements Serializable{ /**  * 功能描述:序列化時候的唯一性,相應的get和set方法已經省略。  */ private static final long serialVersionUID = 1L; /** 主鍵-id uuid */ @Id //此備注代表該字段為該類的主鍵 @GeneratedValue(generator="system-uuid") @GenericGenerator(name="system-uuid",strategy = "uuid") //name - 指定對應列的名稱 ,length - 最大長度 @Column(name="id",length=32) // private String id; /** 數字,具有唯一性 */ //nullable - 是否可以為null,默認為true unique - 是否唯一,默認為false @Column(name="no",nullable=false,unique=true) private Integer no; /** 部門名稱 */ @Column(name="name",unique=true,nullable=false) private String name; /** 部門管理的主鍵-id uuid */ @Column(name="manager",unique=true,nullable=false) private String manager; /** 部門描述 */ @Column(name="description") private String description; /** 部門電話 */ @Column(name="phone") private String phone; /** 部門創建時間 */ @Column(name="createTime")  @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date createTime; /** 部門修改時間 */ @Column(name="editTime")  @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date editTime;}

(1)、@Entity 代表此類映射為數據庫的表結構
(2)、@Table(name="tbl_dept")此注解用于配置實體類與表映射的關系,name代表映射的表名
(3)、 @Id注解代表此類為一個主鍵
(4)、@GeneratedValue注解用于配置主鍵相關信息,generator屬性用于配置生成策略有以下幾種枚舉值:
  1、auto - 主鍵由程序控制 。
  2、IDENTITY - 由數據庫自動生成。
  3、enerator -指定生成主鍵使用的生成器 。
 4、SEQUENCE - 根據底層數據庫的序列來生成主鍵 。
  5、TABLE - 使用一個特定的數據庫表來保存主鍵。
  6、system-uuid 代表使用系統生成的uuid進行配。
(5)、@Column用于配置列相關信息的注解
  1、name字段用于指定映射到表結構的映射字段。
  2、length代表此字段的長度約束,可以省略。
  3、unique屬性代表此字段是否開啟唯一性約束,默認為false,唯一則為true 。
  4、nullable代表此字段是否可以為空,默認為true 。 false代表不能為空 。
(6)、@DateTimeFormat用于映射數據庫表時間的格式。
相應的get和set方法已經省略。

3)DeptRepository層實現

Spring,Data,JPA整合MySQL,JPA,MySQL

如圖,Respository為一個接口規范,有不同的子接口繼承,每個子接口除了繼承父接口所有功能外還會添加額外的方法,用于不同的實現。CrudRepository類定義了基本方法,其子類分別進行擴展。
如PagingAndSortingRepository類除了繼承CrudRepository的所有方法,還額外對其進行擴展,增加了分頁查找的相關方法:

Iterable<T> findAll(Sort sort);Page<T> findAll(Pageable pageable);

而JpaRepository則是在PagingAndSortingRepository的基礎上再進行擴展。

1、Repository層:

@Repository 代表將此類交由spring管理,并且其為一個dao層

/** * @功能描述:用于部門表操作的dao層接口 * @author Administrator */@Repository//代表此為一個dao層實現public interface DeptRepository extends JpaRepository<Dept, String>{}

根據實現類不同,其擁有不同的方法可調用,一般此處方法大家見名知意都能知道其用法。泛型中<Dept, String> 第一個參數代表表映射的實體類,第二個參數代表主鍵類型。

2、Service層實現:

/** * @功能描述:用于部門service操作的實現類 * @author Administrator */@Servicepublic class DeptServiceImpl implements DeptService{ /** 日志處理類 */ private final Logger log = LoggerFactory.getLogger(getClass());  @Autowired private DeptRepository repository;  @Override public Dept queryById(String id) throws Exception {  try {   Dept result = repository.findOne(id);   log.info(result.toString());   return result;  }catch (Exception e) {   log.info(e.toString(),e);   throw new ServiceException("根據id查詢時發生異常!");  } }}

其中findOne為JpaRepository實現的方法。

3、Controller層實現:

@RestController@RequestMapping("/api/v1/dept")public class DeptController{ /** 日志記錄類 */ private Logger log = LoggerFactory.getLogger(getClass()); /** 自家的service */ @Autowired private DeptService service;  /**  * @功能描述:根據id查詢部門內容的方法  * @return Dept  */ @GetMapping("/id/get") public Result getById( String id) throws Exception{  verify(new VerifyParam("部門id", id));  return new Result("通過id獲取部門信息成功!", service.queryById(id)); }}

其中RestController代表此Controller為返回Json格式的控制器,@RequestMapping定義其類映射的url,此處我們接受的數據為普通String類型,如果需要接受Json類型,則需 @RequestBody String id 如此配置接受請求參數。

4 、測試:

Spring,Data,JPA整合MySQL,JPA,MySQL

模擬進行發送get請求,完成Spring-Data-Jpa與MySQL的整合和配置。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人性教育视频在线观看| 2019亚洲男人天堂| 亚洲欧美日韩在线一区| 欧美激情精品久久久| 欧美精品在线观看| 亚洲精品美女久久久| 性色av香蕉一区二区| 亚洲精品资源美女情侣酒店| 在线观看成人黄色| 中文字幕亚洲天堂| 久久韩剧网电视剧| 国产在线精品自拍| 色妞色视频一区二区三区四区| 欧美亚洲日本黄色| 亚洲国产精品一区二区久| 中国人与牲禽动交精品| 国产91网红主播在线观看| 中文字幕国产日韩| 国产日韩换脸av一区在线观看| 国产欧美精品va在线观看| 国产精品国产亚洲伊人久久| 国产成人午夜视频网址| 欧美成人午夜激情| 亚洲成年人影院在线| 国产精品777| 国产亚洲精品美女| 欧美精品在线观看91| 亚洲男人的天堂网站| 91久久久国产精品| 欧美色视频日本高清在线观看| 欧美精品一本久久男人的天堂| 亚洲999一在线观看www| 欧美日韩免费区域视频在线观看| 91在线中文字幕| 久久久精品欧美| 高清欧美电影在线| 久久精品色欧美aⅴ一区二区| 国产做受69高潮| 中文字幕亚洲一区二区三区五十路| 国产精品久久电影观看| 国产精品三级网站| 97涩涩爰在线观看亚洲| 97精品在线观看| 精品国产一区二区在线| 亚洲精品国产综合久久| 久久999免费视频| 91亚洲国产成人精品性色| 亚洲精品国偷自产在线99热| 日本中文字幕成人| 久久精品国产亚洲一区二区| 中文字幕一区二区三区电影| 成人黄色免费网站在线观看| 亚洲2020天天堂在线观看| 日韩中文字幕免费视频| 国产经典一区二区| 尤物九九久久国产精品的特点| 色综合久久88色综合天天看泰| 日韩精品免费综合视频在线播放| 国产欧美精品在线| 国产精品福利在线| 久久国产精品亚洲| 日本午夜精品理论片a级appf发布| 国产成人亚洲综合91精品| 日韩精品在线免费| 97成人精品视频在线观看| 精品偷拍各种wc美女嘘嘘| 久久久av亚洲男天堂| 亚洲福利视频二区| 26uuu另类亚洲欧美日本老年| 国语自产在线不卡| 98精品国产高清在线xxxx天堂| 亚洲第一福利视频| 国产欧美一区二区三区在线看| 精品视频一区在线视频| 97视频免费在线看| 久久亚洲私人国产精品va| 国产精品爽爽ⅴa在线观看| 日本aⅴ大伊香蕉精品视频| 亚洲免费中文字幕| 国产日韩欧美日韩大片| 国产一区二区三区久久精品| 久久人人爽人人| 久久精品国产一区二区电影| 亚洲电影免费观看高清| 亚洲成人黄色在线观看| 国产精品久久久久免费a∨大胸| 欧美激情视频网址| 色综合视频网站| 欧美日韩免费网站| 日韩av免费网站| 亚洲人成网在线播放| 国产精品专区一| 国产精品福利网站| 国产精品综合久久久| 欧美三级欧美成人高清www| 国产亚洲精品综合一区91| 国产97在线观看| 精品日韩中文字幕| 欧美性感美女h网站在线观看免费| 亚洲欧美一区二区三区在线| 欧美激情二区三区| 亚洲爱爱爱爱爱| 国产精品丝袜久久久久久高清| 国产97在线|日韩| 亚洲精品一区av在线播放| 国内外成人免费激情在线视频网站| 日韩在线免费观看视频| 日韩最新av在线| 日韩视频第一页| 国产精品扒开腿做爽爽爽男男| 国产精品第3页| 青青草精品毛片| 亚洲国产高潮在线观看| 久久手机精品视频| 91欧美精品午夜性色福利在线| 亚洲自拍偷拍色图| 久久视频在线播放| 欧美日韩黄色大片| 26uuu亚洲伊人春色| 国产丝袜视频一区| 岛国视频午夜一区免费在线观看| 国产精品久久久久久中文字| 亚洲成av人乱码色午夜| 日韩电影免费在线观看中文字幕| 岛国视频午夜一区免费在线观看| 97国产精品人人爽人人做| 亚洲a成v人在线观看| 亚洲国产天堂久久国产91| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产午夜精品理论片a级探花| 日韩av免费看网站| 亚洲国产精品yw在线观看| 亚洲人成电影网站色| 久久精品99久久久久久久久| 亚洲精品www久久久| 波霸ol色综合久久| 国产男女猛烈无遮挡91| 久久99热这里只有精品国产| 欧美大片第1页| 亚洲高清不卡av| 97视频在线观看网址| 欧美日韩性生活视频| 日韩在线观看免费高清完整版| 国产婷婷成人久久av免费高清| 亚洲欧美日本另类| 日韩欧美极品在线观看| 国产精品丝袜久久久久久高清| 国产精品户外野外| 欧美亚洲国产成人精品| 91亚洲精品一区二区| 美女啪啪无遮挡免费久久网站| 亚洲日本欧美日韩高观看| 亚洲免费视频一区二区| 日韩av网站大全| 91啪国产在线| 91精品视频在线播放| 国产欧美一区二区三区四区| 美女扒开尿口让男人操亚洲视频网站| 亚洲欧洲国产伦综合| 欧美激情在线播放| 国产成人激情小视频| 国产精品福利无圣光在线一区| 国产精品一区二区三区久久久| 亚洲精品www久久久久久广东|