1. 程式人生 > >springboot~JPA把ORM統一起來

springboot~JPA把ORM統一起來

div return update 字段 clas jdb 檢查 pass ora

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‘)
    compile(‘mysql:mysql-connector-java‘)

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

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表示數據列名稱等等。

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

  }
}

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

感謝閱讀!

springboot~JPA把ORM統一起來