springboot~JPA把ORM統一起來


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文件中添加包引用

compile('org.springframework.boot:spring-boot-starter-data-jpa')
runtime('mysql:mysql-connector-java')

2 在source的配置文件中添加mysql和jpa的相關設置

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/test?useSSL=false&createDatabaseIfNotExist=true
    username: root
    password: 123456
    driver-class-name: com.mysql.jdbc.Driver
  jpa:
      database: MYSQL
      show-sql: true #顯示后台處理的SQL語句
      hibernate:
        ddl-auto: update #自動檢查實體和數據庫表是否一致,如果不一致則會進行更新數據庫表

上面代碼中我們開啟了數據庫SQL代碼的顯示功能,我們在控制台上可以看到對應的SQL語句。

Hibernate: select next_val as id_val from hibernate_sequence for update
Hibernate: update hibernate_sequence set next_val= ? where next_val=?
Hibernate: insert into t_userinfo (password, user_name, id) values (?, ?, ?)
Hibernate: select next_val as id_val from hibernate_sequence for update
Hibernate: update hibernate_sequence set next_val= ? where next_val=?
Hibernate: insert into t_accountinfo (balance, user_info, account_id) values (?, ?, ?)

3 添加數據庫表實體,注意一些注解,@Entity表示數據表實體,@Table可以指定數據表名稱,@Id表示是主鍵,@GeneratedValue主鍵升成規則,@Column表示數據列名稱等等。

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實例我們不需要寫了,如果有個性化的操作,再去定義接口和實現。

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();

  }
}

有時間,再和大家聊聊個性化接口和實現的設計!

感謝閱讀!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM