Spring Boot JPA如何把ORM統(tǒng)一起來(lái)
JPA介紹
JPA(Java Persistence API)是Sun官方提出的Java持久化規(guī)范。它為Java開(kāi)發(fā)人員提供了一種對(duì)象/關(guān)聯(lián)映射工具來(lái)管理Java應(yīng)用中的關(guān)系數(shù)據(jù)。他的出現(xiàn)主要是為了簡(jiǎn)化現(xiàn)有的持久化開(kāi)發(fā)工作和整合ORM技術(shù),結(jié)束現(xiàn)在Hibernate,TopLink,JDO等ORM框架各自為營(yíng)的局面。值得注意的是,JPA是在充分吸收了現(xiàn)有Hibernate,TopLink,JDO等ORM框架的基礎(chǔ)上發(fā)展而來(lái)的,具有易于使用,伸縮性強(qiáng)等優(yōu)點(diǎn)。從目前的開(kāi)發(fā)社區(qū)的反應(yīng)上看,JPA受到了極大的支持和贊揚(yáng),其中就包括了Spring與EJB3.0的開(kāi)發(fā)團(tuán)隊(duì)。JPA是一套規(guī)范,不是一套產(chǎn)品,那么像Hibernate,TopLink,JDO他們是一套產(chǎn)品,如果說(shuō)這些產(chǎn)品實(shí)現(xiàn)了這個(gè)JPA規(guī)范,那么我們就可以叫他們?yōu)镴PA的實(shí)現(xiàn)產(chǎn)品。
Spring Data JPA
Spring Data JPA 是 Spring 基于 ORM 框架、JPA 規(guī)范的基礎(chǔ)上封裝的一套JPA應(yīng)用框架,可使開(kāi)發(fā)者用極簡(jiǎn)的代碼即可實(shí)現(xiàn)對(duì)數(shù)據(jù)的訪問(wèn)和操作。它提供了包括增刪改查等在內(nèi)的常用功能,且易于擴(kuò)展!學(xué)習(xí)并使用 Spring Data JPA 可以極大提高開(kāi)發(fā)效率!spring data jpa讓我們解脫了DAO層的操作,基本上所有CRUD都可以依賴于它來(lái)實(shí)現(xiàn),自己寫(xiě)個(gè)倉(cāng)儲(chǔ)接口后繼承JpaRepository即可實(shí)現(xiàn)最基本的增刪改查功能!
在項(xiàng)目中引用Spring JPA
1 在build.gradle文件中添加包引用
compile('org.springframework.boot:spring-boot-starter-data-jpa')
compile('mysql:mysql-connector-java')
2 在source的配置文件中添加mysql和jpa的相關(guān)設(shè)置
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 #顯示后臺(tái)處理的SQL語(yǔ)句
hibernate:
ddl-auto: update #自動(dòng)檢查實(shí)體和數(shù)據(jù)庫(kù)表是否一致,如果不一致則會(huì)進(jìn)行更新數(shù)據(jù)庫(kù)表
3 添加數(shù)據(jù)庫(kù)表實(shí)體,注意一些注解,@Entity表示數(shù)據(jù)表實(shí)體,@Table可以指定數(shù)據(jù)表名稱,@Id表示是主鍵,@GeneratedValue主鍵升成規(guī)則,@Column表示數(shù)據(jù)列名稱等等。
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 為數(shù)據(jù)表實(shí)體添加倉(cāng)儲(chǔ)接口,因?yàn)镴PA已經(jīng)有了自己的標(biāo)準(zhǔn)實(shí)例,所以簡(jiǎn)單的CURD實(shí)例我們不需要寫(xiě)了,如果有個(gè)性化的操作,再去定義接口和實(shí)現(xiàn)。
import com.example.springdemo.model.User;
import org.springframework.data.jpa.repository.JpaRepository;
public interface SqlUserRepository extends JpaRepository<User, Integer> {
}
5 最后在controller中添加依賴注入的字段,一般使用@Autowired即可
@RestController
@RequestMapping("/mysql")
public class MysqlController {
@Autowired
private SqlUserRepository repository;
/**
* return list.
*
* @return
*/
@RequestMapping("/list")
public List<User> dataList() {
return repository.findAll();
}
}
總結(jié)
以上所述是小編給大家介紹的Spring Boot JPA如何把ORM統(tǒng)一起來(lái),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 基于spring boot 1.5.4 集成 jpa+hibernate+jdbcTemplate(詳解)
- 詳解基于Spring Boot與Spring Data JPA的多數(shù)據(jù)源配置
- Spring Boot + Jpa(Hibernate) 架構(gòu)基本配置詳解
- SpringBoot集成Spring Data JPA及讀寫(xiě)分離
- SpringBoot JPA 表關(guān)聯(lián)查詢實(shí)例
- SpringBoot JPA實(shí)現(xiàn)增刪改查、分頁(yè)、排序、事務(wù)操作等功能示例
- Spring Boot中使用Spring-data-jpa實(shí)現(xiàn)數(shù)據(jù)庫(kù)增刪查改
相關(guān)文章
IDEA之IDEA連接gitlab協(xié)同開(kāi)發(fā)方式
通過(guò)IDEA克隆GitLab項(xiàng)目實(shí)現(xiàn)代碼協(xié)同開(kāi)發(fā)相較于使用SourceTree,?通過(guò)IDEA連接GitLab進(jìn)行代碼協(xié)同開(kāi)發(fā)更顯便捷,方法包括通過(guò)VersionControl創(chuàng)建新項(xiàng)目,輸入項(xiàng)目的git?HTTP地址和本地路徑,測(cè)試連接成功后克隆項(xiàng)目,修改代碼后2024-11-11
Spring?Initializr只能創(chuàng)建為Java?17版本以上的問(wèn)題解決
這篇文章主要給大家介紹了關(guān)于Spring?Initializr只能創(chuàng)建為Java?17版本以上問(wèn)題的解決辦法,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01
Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(54)
下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你2021-08-08
Java int與integer的對(duì)比區(qū)別
這篇文章主要介紹了Java int與integer的對(duì)比區(qū)別的相關(guān)資料,需要的朋友可以參考下2017-01-01

