javascript
Spring Boot入门——JPA
JPA最大的特點就是可以根據@Entity自動創建你數據庫表,用戶只需要聲明持久層的接口,不需要實現該接口
1、JPA概念
JPA全稱Java Persistence API,JPA通過JDK5.0注解或XML描述對象、關系表的映射關系,并將運行期的實體對象持久化到數據庫中。
JPA是Sun官方提供發Java持久化規范,為java開發人員提供了一種對象/關系映射工具來管理java應用中的關系數據。
持久化(Persistence),即把數據保存到可永久保存的存儲設備中(如磁盤),持久化的主要應用是將內存中的對象存儲在數據庫中,或者存儲在磁盤文件中或XML數據文件中。
2、Hibernate概念
Hibernate是一個開放源代碼的對象關系映射框架,它對JDBC進行了非常輕量級的對象封裝,它將POJO與數據庫表建立映射關系,是一個全自動的ORM框架??梢宰詣由蒘QL語句,自動執行,使得java程序員可以隨心所欲的使用對象編程的思想來操作數據庫。
3、Spring Boot JPA特點
a、簡潔,只需要聲明接口,接口無需實現
b、簡單易用,提供了多種不同功能的接口
c、集成了多種查詢策略,支持JPQL
d、簡化了排序分頁等功能
e、可以和Spring Boot整合,進一步簡化
f、支持擴展
4、使用Spring Boot JPA的步驟
a、在pom.xml文件中添加mysql,spring-data-jpa依賴
<!-- mysql依賴 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.42</version></dependency><!-- spring-boot-jpa依賴 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency> b、在application.properties文件中配置mysql連接配置信息
# 下面為連接池的補充設置,應用到上面所有數據源中
# 初始化大小,最小,最大
#spring.datasource.initialSize=5
#spring.datasource.minIdle=5
#spring.datasource.maxActive=20
#配置獲取連接等待超時的時間
#spring.datasource.maxWait=60000
#配置間隔多久才進行一次檢測,檢測需要關閉的空閑連接,單位是毫秒
#spring.datasource.timeBetweenEvictionRunsMillis=60000
# 配置一個連接在池中最小生存的時間,單位是毫秒
#spring.datasource.minEvictableIdleTimeMillis=300000
#spring.datasource.validationQuery=SELECT 1 FROM DUAL
#spring.datasource.testWhileIdle=true
#spring.datasource.testOnBorrow=false
#spring.datasource.testOnReturn=false
# 打開PSCache,并且指定每個連接上PSCache的大小
#spring.datasource.poolPreparedStatements=true
#spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
# 配置監控統計攔截的filters,去掉后監控界面sql無法統計,'wall'用于防火墻
#spring.datasource.filters=stat,wall,log4j
# 通過connectProperties屬性來打開mergeSql功能;慢SQL記錄
#spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
# 合并多個DruidDataSource的監控數據
#spring.datasource.useGlobalDataSourceStat=true
c、在application.properties文件中配置JPA配置信息
#spring boot JPA相關配置 spring.jpa.datasource=MYSQL# Show or not log for each sql query spring.jpa.show-sql = true# Hibernate ddl auto (create, create-drop, update) spring.jpa.hibernate.ddl-auto = update# Naming strategy spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy#spring.jpa.database=org.hibernate.dialect.MySQL5InnoDBDialect spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialectd、編寫測試樣例
/* * Grade類 */ package com.wyl.bean;import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id;@Entity public class Grade {@Id@GeneratedValue(strategy=GenerationType.AUTO)//設置id自增長private int id;private String gradeNm;private int teacherId;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getGradeNm() {return gradeNm;}public void setGradeNm(String gradeNm) {this.gradeNm = gradeNm;}public int getTeacherId() {return teacherId;}public void setTeacherId(int teacherId) {this.teacherId = teacherId;} } Grade.class /*** GradeDAO,數據庫操作類必須繼承Repository類
*/
package com.wyl.dao;import org.springframework.data.repository.Repository;import com.wyl.bean.Grade;
/** Spring Boot中dao最重要的就是繼承 Repository類,完成數據庫相應的操作
* GradeDAO也可以繼承CrudRepository類,調用Spring boot中已有的數據庫操作方法更方便
* GradeDAO繼承PagingAndSortingRepository類,完成分頁查詢和排序
* */ public interface GradeDAO extends Repository<Grade, Integer>{
//自定義的數據庫操作方法
//public Grade findByGradeNm(String gradeNm);
@Query("from Grade where gradeNm=:nm")
?? ?public Grade findByGradeNm(@Param("nm")String gradeNm); } package com.wyl.service;import javax.annotation.Resource;import org.springframework.stereotype.Service;import com.wyl.bean.Grade; import com.wyl.dao.GradeDAO;/*** GradeService類,調用gradeDAO中的方法* */ @Service public class GradeService {@Resourceprivate GradeDAO gradeDAO;
@Transactionalpublic Grade findByGradeNm(String gradeNm){return gradeDAO.findByGradeNm(gradeNm);}
//分頁查詢
/*@Transactional
?? ?public Iterable<Grade> getAll(){
?? ??? ?return gradeDAO3.findAll(new PageRequest(0, 4));
?? ?}
?? ?
//排序查詢
?? ?@Transactional
?? ?public Iterable<Grade> getAll2(){
?? ??? ?Sort sort = new Sort(Sort.Direction.DESC, "teacherId");
?? ??? ?return gradeDAO3.findAll(sort);
?? ?}*/ } package com.wyl.controller;import javax.annotation.Resource;import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import com.wyl.bean.Grade; import com.wyl.service.GradeService;@RestController public class JPAController {@Resourceprivate GradeService gradeService;@RequestMapping("/finfByGradeNm")public Grade finfByGradeNm(String gradeNm){System.out.println("finfByGradeNm");return gradeService.findByGradeNm(gradeNm);} }
e、測試結果
轉載于:https://www.cnblogs.com/studyDetail/p/7017754.html
總結
以上是生活随笔為你收集整理的Spring Boot入门——JPA的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [Groovy] 实战 Groovy,
- 下一篇: Mysql定时执行任务实现方法