Spring-Data-JPA整合MySQL和配置的方法
一、簡介
(1)、MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫系統(tǒng),是如今互聯(lián)網(wǎng)公司最常用的數(shù)據(jù)庫和最廣泛的數(shù)據(jù)庫。為服務(wù)端數(shù)據(jù)庫,能承受高并發(fā)的訪問量。
(2)、Spring-Data-Jpa是在JPA規(guī)范下提供的Repository層的實(shí)現(xiàn),可以使用不同的實(shí)現(xiàn)框架如Hibernate、OpenJpa等框架進(jìn)行開發(fā),這樣可以使得Repository變得簡單,也解決了其與業(yè)務(wù)層的耦合性。
本此學(xué)習(xí)我們使用MySQL+Spring-Data-Jpa搭建,Jpa實(shí)現(xiàn)方式使用Hibernate,數(shù)據(jù)庫連接池使用dbcp進(jìn)行連接
二、項(xiàng)目搭建
1、引入MySQL以及Jpa相關(guān)依賴:
<!-- spring-jdbc相關(guān)依賴 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> </dependency> <!-- 用于連接mysql的相關(guān)依賴 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!-- jpa相關(guān)的依賴 包含spring-data-jpa、spring-orm 和 Hibernate 來支持 JPA --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency>
需要引入三個(gè)依賴,jdbc為spring整合MySQL需要的依賴,第二個(gè)為MySQL的數(shù)據(jù)庫驅(qū)動依賴,第三個(gè)為Spring-Data-Jpa相關(guān)的依賴包含:
其中其包含AOP、jdbc、Spring-ORM、事務(wù)Transaction-api和Hibernate等依賴來支持。所以Jpa默認(rèn)為使用Hibernate進(jìn)行實(shí)現(xiàn)。
2 、配置文件配置:
配置文件我們選擇.yml格式文件進(jìn)行配置,并且使用dpcp2配置連接池參數(shù):
1)項(xiàng)目相關(guān)配置:
server: #配置端口號 port: 8088 spring: application: #配置服務(wù)名稱 name: cms-dept
此處為配置配置服務(wù)器開啟的相關(guān)信息,主要為配置服務(wù)器名稱和端口
2)MySQL相關(guān)配置
spring: #數(shù)據(jù)源和jpa配置 datasource: #數(shù)據(jù)庫相關(guān)的配置url -SSL連接設(shè)置為false url: jdbc:mysql://localhost:3306/crm?characterEncoding=utf8&useSSL=false #配置用戶名 username: *** #配置密碼 password: ***
此處為數(shù)據(jù)庫相關(guān)的一些配置,主要為配置數(shù)據(jù)庫url、賬號和密碼。url后配置信息為連接MySQL的編碼格式和是否啟用SSL加密。
3)DBCP相關(guān)配置
spring: #下面為連接池相關(guān)配置 dbcp2: #初始化連接池大小 initial-size: 10 #陪住最小連接池?cái)?shù) min-idle: 10 #配置最大連接池?cái)?shù) max-idle: 30 #配置獲取超時(shí)連接的等待時(shí)間 max-wait-millis: 30000 #配置多長時(shí)間進(jìn)行一次檢測,檢測需要關(guān)閉的數(shù)據(jù)庫連接 time-between-eviction-runs-millis: 200000 #配置連接在連接池的最小生存時(shí)間 remove-abandoned-on-maintenance: 200000
主要配置為一些連接池的信息,配置詳情如上注釋所示。
4)Spring-Data-Jpa依據(jù)iHibernata相關(guān)配置
spring: jpa: #配置數(shù)據(jù)庫類型 database: MYSQL #配置是否打印sql show-sql: true #Hibernate相關(guān)配置 hibernate: #配置級聯(lián)等級 ddl-auto: update naming: #命名策略 strategy: org.hibernate.cfg.ImprovedNamingStrategy properties: hibernate: dialect: org.hibernate.dialect.MySQL5Dialect
配置依次為連接數(shù)據(jù)庫類型,是否打印Sql和hIbernate級聯(lián)方式,有以下幾種:
1)、validate- 加載hibernate時(shí),驗(yàn)證創(chuàng)建數(shù)據(jù)庫表結(jié)構(gòu)。
2)、create- 每次加載hibernate,重新創(chuàng)建數(shù)據(jù)庫表結(jié)構(gòu),這就是導(dǎo)致數(shù)據(jù)庫表數(shù)據(jù)丟失的原因。
3)、create-drop 加載hibernate時(shí)創(chuàng)建,退出是刪除表結(jié)構(gòu)。
4)、update-級聯(lián)更新 加載hibernate自動更新數(shù)據(jù)庫結(jié)構(gòu)。
我們在此選擇級聯(lián)更新,在原有表基礎(chǔ)上進(jìn)行迭代。
命名策略有以下兩種:
1)、 org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy 遇到大寫字母 加”_”的命名。
2)、 org.hibernate.cfg.ImprovedNamingStrategy 無修改命名 。
3 、相關(guān)類進(jìn)行配置:
配置類需要配置與氣動類的平級目錄或者子目錄下,才能被配置成功,此處我們使用Java類配置取代xml方式進(jìn)行配置:
/** * @功能描述:用于MySQL相關(guān)配置的類 * @author Administrator */ //下面此行用來排序的注解接口,用于處理加載優(yōu)先級的問題,擁有兩個(gè)枚舉變量 @Order(Ordered.HIGHEST_PRECEDENCE) //下面此行代表此類為配置類 @Configuration //下面此行代表此類開啟事務(wù)管理 @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注解,用于配置類的加載優(yōu)先級別,其擁有兩個(gè)枚舉變量:
Ordered.HIGHEST_PRECEDENCE- Integer.MIN_VALUE -最小值,擁有最高優(yōu)先級
Ordered.LOWEST_PRECEDENCE -Integer.MAX_VALUE -最大值,擁有最低優(yōu)先級
2)、@Configuration 注解,代表此類為配置類
3)、@EnableTransactionManagement 用于MySQL的事務(wù)管理 proxyTargetClass= true代表開啟類的事務(wù)管理
4)、@EnableJpaRepositories 用于配置事務(wù),此處以cgnl表達(dá)式表示路徑,也可以定義為具體的類,例如DeptRepository.class
其子元素includeFilters可以定義事務(wù)攔截器,如includeFilters={ @ComponentScan.Filter(type=FilterType.ANNOTATION,value=Service.class)}
4 、ORM映射Java類相關(guān)代碼:
1)數(shù)據(jù)庫表結(jié)構(gòu)
2)實(shí)體類映射
@Entity //代表此類為一個(gè)表的映射entity類 @Table(name="tbl_dept") //設(shè)置對應(yīng)的表名 public class Dept implements Serializable{ /** * 功能描述:序列化時(shí)候的唯一性,相應(yīng)的get和set方法已經(jīng)省略。 */ private static final long serialVersionUID = 1L; /** 主鍵-id uuid */ @Id //此備注代表該字段為該類的主鍵 @GeneratedValue(generator="system-uuid") @GenericGenerator(name="system-uuid",strategy = "uuid") //name - 指定對應(yīng)列的名稱 ,length - 最大長度 @Column(name="id",length=32) // private String id; /** 數(shù)字,具有唯一性 */ //nullable - 是否可以為null,默認(rèn)為true unique - 是否唯一,默認(rèn)為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; /** 部門創(chuàng)建時(shí)間 */ @Column(name="createTime") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date createTime; /** 部門修改時(shí)間 */ @Column(name="editTime") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date editTime; }
(1)、@Entity 代表此類映射為數(shù)據(jù)庫的表結(jié)構(gòu)
(2)、@Table(name="tbl_dept")此注解用于配置實(shí)體類與表映射的關(guān)系,name代表映射的表名
(3)、 @Id注解代表此類為一個(gè)主鍵
(4)、@GeneratedValue注解用于配置主鍵相關(guān)信息,generator屬性用于配置生成策略有以下幾種枚舉值:
1、auto - 主鍵由程序控制 。
2、IDENTITY - 由數(shù)據(jù)庫自動生成。
3、enerator -指定生成主鍵使用的生成器 。
4、SEQUENCE - 根據(jù)底層數(shù)據(jù)庫的序列來生成主鍵 。
5、TABLE - 使用一個(gè)特定的數(shù)據(jù)庫表來保存主鍵。
6、system-uuid 代表使用系統(tǒng)生成的uuid進(jìn)行配。
(5)、@Column用于配置列相關(guān)信息的注解
1、name字段用于指定映射到表結(jié)構(gòu)的映射字段。
2、length代表此字段的長度約束,可以省略。
3、unique屬性代表此字段是否開啟唯一性約束,默認(rèn)為false,唯一則為true 。
4、nullable代表此字段是否可以為空,默認(rèn)為true 。 false代表不能為空 。
(6)、@DateTimeFormat用于映射數(shù)據(jù)庫表時(shí)間的格式。
相應(yīng)的get和set方法已經(jīng)省略。
3)DeptRepository層實(shí)現(xiàn)
如圖,Respository為一個(gè)接口規(guī)范,有不同的子接口繼承,每個(gè)子接口除了繼承父接口所有功能外還會添加額外的方法,用于不同的實(shí)現(xiàn)。CrudRepository類定義了基本方法,其子類分別進(jìn)行擴(kuò)展。
如PagingAndSortingRepository類除了繼承CrudRepository的所有方法,還額外對其進(jìn)行擴(kuò)展,增加了分頁查找的相關(guān)方法:
Iterable<T> findAll(Sort sort); Page<T> findAll(Pageable pageable);
而JpaRepository則是在PagingAndSortingRepository的基礎(chǔ)上再進(jìn)行擴(kuò)展。
1、Repository層:
@Repository 代表將此類交由spring管理,并且其為一個(gè)dao層
/** * @功能描述:用于部門表操作的dao層接口 * @author Administrator */ @Repository//代表此為一個(gè)dao層實(shí)現(xiàn) public interface DeptRepository extends JpaRepository<Dept, String>{ }
根據(jù)實(shí)現(xiàn)類不同,其擁有不同的方法可調(diào)用,一般此處方法大家見名知意都能知道其用法。泛型中<Dept, String> 第一個(gè)參數(shù)代表表映射的實(shí)體類,第二個(gè)參數(shù)代表主鍵類型。
2、Service層實(shí)現(xiàn):
/** * @功能描述:用于部門service操作的實(shí)現(xiàn)類 * @author Administrator */ @Service public 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("根據(jù)id查詢時(shí)發(fā)生異常!"); } } }
其中findOne為JpaRepository實(shí)現(xiàn)的方法。
3、Controller層實(shí)現(xiàn):
@RestController @RequestMapping("/api/v1/dept") public class DeptController{ /** 日志記錄類 */ private Logger log = LoggerFactory.getLogger(getClass()); /** 自家的service */ @Autowired private DeptService service; /** * @功能描述:根據(jù)id查詢部門內(nèi)容的方法 * @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,此處我們接受的數(shù)據(jù)為普通String類型,如果需要接受Json類型,則需 @RequestBody String id 如此配置接受請求參數(shù)。
4 、測試:
模擬進(jìn)行發(fā)送get請求,完成Spring-Data-Jpa與MySQL的整合和配置。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JPA之映射mysql text類型的問題
- Springboot2.0配置JPA多數(shù)據(jù)源連接兩個(gè)mysql數(shù)據(jù)庫方式
- Spring boot基于JPA訪問MySQL數(shù)據(jù)庫的實(shí)現(xiàn)
- 解決springboot的JPA在Mysql8新增記錄失敗的問題
- Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼
- springboot使用spring-data-jpa操作MySQL數(shù)據(jù)庫
- SpringBoot連接MYSQL數(shù)據(jù)庫并使用JPA進(jìn)行操作
- Spring Boot 添加MySQL數(shù)據(jù)庫及JPA實(shí)例
- 在JPA項(xiàng)目啟動時(shí)如何新增MySQL字段
相關(guān)文章
logback-spring.xml的配置及示例詳解(直接復(fù)制粘貼可用)
在使用logback作為日志框架時(shí),可以創(chuàng)建一個(gè)名為logback-spring.xml的配置文件來自定義日志輸出的格式和方式,下面這篇文章主要給大家介紹了關(guān)于logback-spring.xml的配置及示例詳解的相關(guān)資料,文中的代碼直接復(fù)制粘貼可用,需要的朋友可以參考下2024-01-01使用dom4j解析xml文件,并轉(zhuǎn)出json格式問題
這篇文章主要介紹了使用dom4j解析xml文件,并轉(zhuǎn)出json格式問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09SpringBoot實(shí)現(xiàn)application.yml文件敏感信息加密
本文主要介紹了SpringBoot實(shí)現(xiàn)application.yml文件敏感信息加密,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07詳解Spring-boot中讀取config配置文件的兩種方式
這篇文章主要介紹了詳解Spring-boot中讀取config配置文件的兩種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10Springboot實(shí)現(xiàn)多數(shù)據(jù)源切換詳情
這篇文章主要介紹了Springboot實(shí)現(xiàn)多數(shù)據(jù)源切換詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的朋友可以參考一下2022-09-09