真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Spring-Data-JPA如何整合MySQL和配置

小編給大家分享一下Spring-Data-JPA如何整合MySQL和配置,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

公司主營(yíng)業(yè)務(wù):成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)建站是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)建站推出保德免費(fèi)做網(wǎng)站回饋大家。

一、簡(jiǎn)介

(1)、MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)系統(tǒng),是如今互聯(lián)網(wǎng)公司最常用的數(shù)據(jù)庫(kù)和最廣泛的數(shù)據(jù)庫(kù)。為服務(wù)端數(shù)據(jù)庫(kù),能承受高并發(fā)的訪問量。

(2)、Spring-Data-Jpa是在JPA規(guī)范下提供的Repository層的實(shí)現(xiàn),可以使用不同的實(shí)現(xiàn)框架如Hibernate、OpenJpa等框架進(jìn)行開發(fā),這樣可以使得Repository變得簡(jiǎn)單,也解決了其與業(yè)務(wù)層的耦合性。

我們使用MySQL+Spring-Data-Jpa搭建,Jpa實(shí)現(xiàn)方式使用Hibernate,數(shù)據(jù)庫(kù)連接池使用dbcp進(jìn)行連接

二、項(xiàng)目搭建

 1、引入MySQL以及Jpa相關(guān)依賴:



 org.springframework
 spring-jdbc



 mysql
 mysql-connector-java



 org.springframework.boot
 spring-boot-starter-data-jpa

需要引入三個(gè)依賴,jdbc為spring整合MySQL需要的依賴,第二個(gè)為MySQL的數(shù)據(jù)庫(kù)驅(qū)動(dòng)依賴,第三個(gè)為Spring-Data-Jpa相關(guān)的依賴包含:

Spring-Data-JPA如何整合MySQL和配置

其中其包含AOP、jdbc、Spring-ORM、事務(wù)Transaction-api和Hibernate等依賴來(lái)支持。所以Jpa默認(rèn)為使用Hibernate進(jìn)行實(shí)現(xiàn)。

2 、配置文件配置:

配置文件我們選擇.yml格式文件進(jìn)行配置,并且使用dpcp2配置連接池參數(shù):

1)項(xiàng)目相關(guān)配置:

server:
 #配置端口號(hào)
 port: 8088
spring:
 application: 
 #配置服務(wù)名稱
 name: cms-dept

此處為配置配置服務(wù)器開啟的相關(guān)信息,主要為配置服務(wù)器名稱和端口

2)MySQL相關(guān)配置

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

此處為數(shù)據(jù)庫(kù)相關(guān)的一些配置,主要為配置數(shù)據(jù)庫(kù)url、賬號(hào)和密碼。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
  #配置多長(zhǎng)時(shí)間進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的數(shù)據(jù)庫(kù)連接
  time-between-eviction-runs-millis: 200000
  #配置連接在連接池的最小生存時(shí)間
  remove-abandoned-on-maintenance: 200000

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

4)Spring-Data-Jpa依據(jù)iHibernata相關(guān)配置

spring: 
 jpa:
 #配置數(shù)據(jù)庫(kù)類型
 database: MYSQL
 #配置是否打印sql
 show-sql: true
 #Hibernate相關(guān)配置
 hibernate:
  #配置級(jí)聯(lián)等級(jí) 
  ddl-auto: update
  naming:
  #命名策略
  strategy: org.hibernate.cfg.ImprovedNamingStrategy
 properties:
  hibernate: 
  dialect: org.hibernate.dialect.MySQL5Dialect

配置依次為連接數(shù)據(jù)庫(kù)類型,是否打印Sql和hIbernate級(jí)聯(lián)方式,有以下幾種:

1)、validate- 加載hibernate時(shí),驗(yàn)證創(chuàng)建數(shù)據(jù)庫(kù)表結(jié)構(gòu)。

2)、create- 每次加載hibernate,重新創(chuàng)建數(shù)據(jù)庫(kù)表結(jié)構(gòu),這就是導(dǎo)致數(shù)據(jù)庫(kù)表數(shù)據(jù)丟失的原因。

3)、create-drop 加載hibernate時(shí)創(chuàng)建,退出是刪除表結(jié)構(gòu)。

4)、update-級(jí)聯(lián)更新 加載hibernate自動(dòng)更新數(shù)據(jù)庫(kù)結(jié)構(gòu)。

我們?cè)诖诉x擇級(jí)聯(lián)更新,在原有表基礎(chǔ)上進(jìn)行迭代。

命名策略有以下兩種:

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

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

3 、相關(guān)類進(jìn)行配置:

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

/**
 * @功能描述:用于MySQL相關(guān)配置的類
 * @author Administrator
 */
//下面此行用來(lái)排序的注解接口,用于處理加載優(yōu)先級(jí)的問題,擁有兩個(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)先級(jí)別,其擁有兩個(gè)枚舉變量:
 Ordered.HIGHEST_PRECEDENCE- Integer.MIN_VALUE -最小值,擁有最高優(yōu)先級(jí)
 Ordered.LOWEST_PRECEDENCE -Integer.MAX_VALUE -最大值,擁有最低優(yōu)先級(jí)

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ù)庫(kù)表結(jié)構(gòu)

Spring-Data-JPA如何整合MySQL和配置
 

2)實(shí)體類映射

@Entity //代表此類為一個(gè)表的映射entity類
@Table(name="tbl_dept") //設(shè)置對(duì)應(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 - 指定對(duì)應(yīng)列的名稱 ,length - 最大長(zhǎng)度
 @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ù)庫(kù)的表結(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ù)庫(kù)自動(dòng)生成。
3、enerator -指定生成主鍵使用的生成器 。
4、SEQUENCE - 根據(jù)底層數(shù)據(jù)庫(kù)的序列來(lái)生成主鍵 。
5、TABLE - 使用一個(gè)特定的數(shù)據(jù)庫(kù)表來(lái)保存主鍵。
6、system-uuid 代表使用系統(tǒng)生成的uuid進(jìn)行配。
(5)、@Column用于配置列相關(guān)信息的注解
1、name字段用于指定映射到表結(jié)構(gòu)的映射字段。
2、length代表此字段的長(zhǎng)度約束,可以省略。
3、unique屬性代表此字段是否開啟唯一性約束,默認(rèn)為false,唯一則為true 。
4、nullable代表此字段是否可以為空,默認(rèn)為true 。 false代表不能為空 。
(6)、@DateTimeFormat用于映射數(shù)據(jù)庫(kù)表時(shí)間的格式。
相應(yīng)的get和set方法已經(jīng)省略。

3)DeptRepository層實(shí)現(xiàn)

Spring-Data-JPA如何整合MySQL和配置

如圖,Respository為一個(gè)接口規(guī)范,有不同的子接口繼承,每個(gè)子接口除了繼承父接口所有功能外還會(huì)添加額外的方法,用于不同的實(shí)現(xiàn)。CrudRepository類定義了基本方法,其子類分別進(jìn)行擴(kuò)展。
如PagingAndSortingRepository類除了繼承CrudRepository的所有方法,還額外對(duì)其進(jìn)行擴(kuò)展,增加了分頁(yè)查找的相關(guān)方法:

Iterable findAll(Sort sort);
Page 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{

}

根據(jù)實(shí)現(xiàn)類不同,其擁有不同的方法可調(diào)用,一般此處方法大家見名知意都能知道其用法。泛型中 第一個(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 如此配置接受請(qǐng)求參數(shù)。

4 、測(cè)試:

Spring-Data-JPA如何整合MySQL和配置

模擬進(jìn)行發(fā)送get請(qǐng)求,完成Spring-Data-Jpa與MySQL的整合和配置。

以上是“Spring-Data-JPA如何整合MySQL和配置”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


當(dāng)前名稱:Spring-Data-JPA如何整合MySQL和配置
本文網(wǎng)址:http://weahome.cn/article/pecjop.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部