SpringBootJPA如何把ORM統(tǒng)一起來

JPA介紹

JPA(Java Persistence API)是Sun官方提出的Java持久化規(guī)范。它為Java開發(fā)人員提供了一種對象/關(guān)聯(lián)映射工具來管理Java應(yīng)用中的關(guān)系數(shù)據(jù)。他的出現(xiàn)主要是為了簡化現(xiàn)有的持久化開發(fā)工作和整合ORM技術(shù),結(jié)束現(xiàn)在Hibernate,TopLink,JDO等ORM框架各自為營的局面。值得注意的是,JPA是在充分吸收了現(xiàn)有Hibernate,TopLink,JDO等ORM框架的基礎(chǔ)上發(fā)展而來的,具有易于使用,伸縮性強(qiáng)等優(yōu)點(diǎn)。從目前的開發(fā)社區(qū)的反應(yīng)上看,JPA受到了極大的支持和贊揚(yáng),其中就包括了Spring與EJB3.0的開發(fā)團(tuán)隊(duì)。JPA是一套規(guī)范,不是一套產(chǎn)品,那么像Hibernate,TopLink,JDO他們是一套產(chǎn)品,如果說這些產(chǎn)品實(shí)現(xiàn)了這個(gè)JPA規(guī)范,那么我們就可以叫他們?yōu)镴PA的實(shí)現(xiàn)產(chǎn)品。

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比永順網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式永順網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋永順地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。

Spring Data JPA

Spring Data JPA 是 Spring 基于 ORM 框架、JPA 規(guī)范的基礎(chǔ)上封裝的一套JPA應(yīng)用框架,可使開發(fā)者用極簡的代碼即可實(shí)現(xiàn)對數(shù)據(jù)的訪問和操作。它提供了包括增刪改查等在內(nèi)的常用功能,且易于擴(kuò)展!學(xué)習(xí)并使用 Spring Data JPA 可以極大提高開發(fā)效率!spring data jpa讓我們解脫了DAO層的操作,基本上所有CRUD都可以依賴于它來實(shí)現(xiàn),自己寫個(gè)倉儲接口后繼承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 #顯示后臺處理的SQL語句
   hibernate:
    ddl-auto: update #自動檢查實(shí)體和數(shù)據(jù)庫表是否一致,如果不一致則會進(jìn)行更新數(shù)據(jù)庫表

3 添加數(shù)據(jù)庫表實(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í)體添加倉儲接口,因?yàn)镴PA已經(jīng)有了自己的標(biāo)準(zhǔn)實(shí)例,所以簡單的CURD實(shí)例我們不需要寫了,如果有個(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)一起來,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!

分享名稱:SpringBootJPA如何把ORM統(tǒng)一起來
新聞來源:http://muchs.cn/article4/pdpioe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、網(wǎng)站策劃靜態(tài)網(wǎng)站、品牌網(wǎng)站設(shè)計(jì)品牌網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管