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的實現產品。java

Spring Data JPA

Spring Data JPA 是 Spring 基於 ORM 框架、JPA 規範的基礎上封裝的一套JPA應用框架,可以使開發者用極簡的代碼便可實現對數據的訪問和操做。它提供了包括增刪改查等在內的經常使用功能,且易於擴展!學習並使用 Spring Data JPA 能夠極大提升開發效率!spring data jpa讓咱們解脫了DAO層的操做,基本上全部CRUD均可以依賴於它來實現,本身寫個倉儲接口後繼承JpaRepository便可實現最基本的增刪改查功能!mysql

在項目中引用Spring JPA

1 在build.gradle文件中添加包引用spring

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

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

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

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便可spring-boot

@RestController
@RequestMapping("/mysql")
public class MysqlController {

  @Autowired
  private SqlUserRepository repository;

  /**
   * return list.
   *
   * @return
   */
  @RequestMapping("/list")
  public List<User> dataList() {
    return repository.findAll();

  }
}

有時間,再和你們聊聊個性化接口和實現的設計!工具

感謝閱讀!學習

相關文章
相關標籤/搜索