JPA介紹
JPA(Java Persistence API)是Sun官方提出的Java持久化規范。它為Java開發人員提供了一種對象/關聯映射工具來管理Java應用中的關系數據。他的出現主要是為了簡化現有的持久化開發工作和整合ORM技術,結束現在Hibernate,TopLink,JDO等ORM框架各自為營的局面。值得注意的是,JPA是在充分吸收了現有Hibernate,TopLink,JDO等ORM框架的基礎上發展而來的,具有易于使用,伸縮性強等優點。從目前的開發社區的反應上看,JPA受到了極大的支持和贊揚,其中就包括了Spring與EJB3.0的開發團隊。JPA是一套規范,不是一套產品,那么像Hibernate,TopLink,JDO他們是一套產品,如果說這些產品實現了這個JPA規范,那么我們就可以叫他們為JPA的實現產品。
Spring Data JPA
Spring Data JPA 是 Spring 基于 ORM 框架、JPA 規范的基礎上封裝的一套JPA應用框架,可使開發者用極簡的代碼即可實現對數據的訪問和操作。它提供了包括增刪改查等在內的常用功能,且易于擴展!學習并使用 Spring Data JPA 可以極大提高開發效率!spring data jpa讓我們解脫了DAO層的操作,基本上所有CRUD都可以依賴于它來實現,自己寫個倉儲接口后繼承JpaRepository即可實現最基本的增刪改查功能!
在項目中引用Spring JPA
1 在build.gradle文件中添加包引用
1
2
|
compile( 'org.springframework.boot:spring-boot-starter-data-jpa' ) compile( 'mysql:mysql-connector-java' ) |
2 在source的配置文件中添加mysql和jpa的相關設置
1
2
3
4
5
6
7
8
9
10
11
|
spring: datasource: url: jdbc:mysql: //127.0.0.1:3306/test username: root password: root driver- class -name: com.mysql.jdbc.Driver jpa: database: MYSQL show-sql: true #顯示后臺處理的SQL語句 hibernate: ddl-auto: update #自動檢查實體和數據庫表是否一致,如果不一致則會進行更新數據庫表 |
3 添加數據庫表實體,注意一些注解,@Entity表示數據表實體,@Table可以指定數據表名稱,@Id表示是主鍵,@GeneratedValue主鍵升成規則,@Column表示數據列名稱等等。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.Table; import lombok.Data; @Data @Entity @Table (name = "user" ) public class User { @Id @GeneratedValue (strategy = GenerationType.AUTO) @Column (name = "Id" ) private int id; @Column (name = "Name" ) private String name; } |
4 為數據表實體添加倉儲接口,因為JPA已經有了自己的標準實例,所以簡單的CURD實例我們不需要寫了,如果有個性化的操作,再去定義接口和實現。
1
2
3
4
|
import com.example.springdemo.model.User; import org.springframework.data.jpa.repository.JpaRepository; public interface SqlUserRepository extends JpaRepository<User, Integer> { } |
5 最后在controller中添加依賴注入的字段,一般使用@Autowired即可
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
@RestController @RequestMapping ( "/mysql" ) public class MysqlController { @Autowired private SqlUserRepository repository; /** * return list. * * @return */ @RequestMapping ( "/list" ) public List<User> dataList() { return repository.findAll(); } } |
總結
以上所述是小編給大家介紹的Spring Boot JPA如何把ORM統一起來,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:https://www.cnblogs.com/lori/archive/2018/04/18/8874323.html