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 基於 ORM 框架、JPA 規範的基礎上封裝的一套JPA應用框架,可以使開發者用極簡的代碼便可實現對數據的訪問和操做。它提供了包括增刪改查等在內的經常使用功能,且易於擴展!學習並使用 Spring Data JPA 能夠極大提升開發效率!spring data jpa讓咱們解脫了DAO層的操做,基本上全部CRUD均可以依賴於它來實現,本身寫個倉儲接口後繼承JpaRepository便可實現最基本的增刪改查功能!mysql
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(); } }
有時間,再和你們聊聊個性化接口和實現的設計!工具
感謝閱讀!學習