Spring Boot2.x整合JPA快速開發的示例程式碼
什麼是JPA
一種規範,並非ORM框架,也就是ORM上統一的規範
- spring-boot-starter-data-jpa是Spring Boot的專案,包含了spring-data-jpa和一些其他依賴用於Spring Boot專案
- spring-data-jpa是Spring Data的專案,就是本體,用於任何專案
解決
- 為了執行簡單查詢分頁,編寫太多重複程式碼
- 基於JPA的資料訪問層的增強支援
用了之後可以做什麼,為什麼要用?如下程式碼解釋
實體類
package com.example.springredis.entity; import lombok.Data; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import java.io.Serializable; @Entity @Data public class User implements Serializable { @Id @GeneratedValue(strategy = GenerationType.AUTO) private Long id; private String name; private String account; private String pwd; }
dao層
@Repository public interface UserDao extends JpaRepository<User,Long> { }
測試類
@Autowired private UserDao userDao; public void findAllTest() { System.out.println(userDao.findAll().toString()); }
上面的操作已經完成了一個查詢全部,相信不用在做多餘的解釋了
JPA優點:主要就是簡單易用,整合方便,可以不用寫SQL語句
準備工作
- JDK 1.8 以上
- IDEA 2020.3
- Gradle 5+ 或者 Maven 3.5+
- 在 https://start.spring.io/ 初始化一個專案
這裡使用的是Maven,下載之後請在IDEA匯入專案
專案結構圖
先看pom.xml配置
國外依賴下載慢,更換阿里源
<?xml version="1.0" encoding="UTF-8"?> <project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.0.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>springboot-jpa</artifactId> <version>0.0.1-SNAPSHOT</version> <name>springboot-jpa</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> <repositories> <!--阿里雲主倉庫,代理了maven central和jcenter倉庫--> <repository> <id>aliyun</id> <name>aliyun</name> <url>https://maven.aliyun.com/repository/public</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>false</enabled> </snapshots> </repository> <!--阿里雲代理Spring 官方倉庫--> <repository> <id>spring-milestones</id> <name>Spring Milestones</name> <url>https://maven.aliyun.com/repository/spring</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories> </project>
定義一個實體物件 SysUser.java
package com.example.demo.model; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; @Data @NoArgsConstructor @AllArgsConstructor @Entity(name = "sys_user") public class SysUser { @Id @GeneratedValue(strategy = GenerationType.AUTO) private Long id; private String email; private String username; private String password; public SysUser(String email,String username,String password) { this.email = email; this.username = username; this.password = password; } }
- 這裡有一個
**SysUser**
類,@NoArgsConstructor
預設建構函式僅為JPA而存在。 - 另一個建構函式是您將用於建立要儲存到資料庫的user例項的建構函式。
- 在類上加
@Entity
註解,表示這個是一個 JPA 的實體,如果在類上沒有加@Table
註解,表明該實體將對映到名為sys_user
的表,如果要加上,可以在其 name 屬性裡寫入表名,如:@Table(name = "t_user")
id
屬性使用@Id
註釋,以便JPA將其識別為物件的ID.- @GeneratedValue(strategy = GenerationType.AUTO) 自增長ID策略
建立一個 UserRepository.java 介面
這裡很簡單,直接繼承核心介面 JpaRepository
package com.example.demo.repository; import com.example.demo.model.SysUser; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.stereotype.Repository; @Repository public interface UserRepository extends JpaRepository<SysUser,Long> { }
配置檔案application.yml
修改application.properties 為 application.yml
src/main/resources/application.yml
spring: datasource: driverClassName: org.h2.Driver password: root url: jdbc:h2:mem:demodb:file:data/demo username: root jpa: open-in-view: true database-platform: org.hibernate.dialect.H2Dialect # spring.jpa.show-sql=true 配置在日誌中打印出執行的 SQL 語句資訊。 show-sql: true # 配置指明在程式啟動的時候要刪除並且建立實體類對應的表。 # create 這個引數很危險,因為他會把對應的表刪除掉然後重建。所以千萬不要在生成環境中使用。只有在測試環境中,一開始初始化資料庫結構的時候才能使用一次。 # ddl-auto:create----每次執行該程式,沒有表格會新建表格,表內有資料會清空 # ddl-auto:create-drop----每次程式結束的時候會清空表 # ddl-auto:update----每次執行程式,沒有表格會新建表格,表內有資料不會清空,只會更新(推薦) # ddl-auto:validate----執行程式會校驗資料與資料庫的欄位型別是否相同,不同會報錯 hibernate.ddl-auto: update
h2資料庫
在resources 資料夾下新建 data.sql
data.sql
DROP TABLE IF EXISTS sys_user; CREATE TABLE sys_user ( id INT AUTO_INCREMENT PRIMARY KEY,email VARCHAR(250) DEFAULT NULL,username VARCHAR(250) NOT NULL,password VARCHAR(250) NOT NULL );
測試類進行測試SpringbootJpaApplicationTests.java
package com.example.demo; import com.example.demo.model.SysUser; import com.example.demo.repository.UserRepository; import lombok.extern.slf4j.Slf4j; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @Slf4j @RunWith(SpringRunner.class) @SpringBootTest public class SpringbootJpaApplicationTests { @Autowired private UserRepository userRepository; @Before public void add() { userRepository.save(new SysUser("[email protected]","root","root")); } @Test public void contextLoads() { System.out.println(userRepository.findAll().toString()); } //修改操作 @After public void update() { // ifPresent 如果存在值,則使用值呼叫指定的使用者,否則不執行任何操作。 userRepository.findById(1L).ifPresent(user -> { user.setUsername("馬華雲騰"); userRepository.save(user); System.out.println(user.toString()); }); } //刪除 @After public void del() { userRepository.findById(2L).ifPresent(user -> userRepository.delete(user)); } }
測試輸出
常見異常
如果出現下列等錯誤:
Error:(41,13) java: 找不到符號
符號: 方法 setName(java.lang.String)
位置: 型別為com.example.springbootjpademo.entity.User的變數 user
請注意下面的設定是否正確:
RestClient API 測試
### 新增1 POST http://localhost:8080/user/add Content-Type: application/json { "email": "[email protected]","username": "root","password": "root" } ### 新增2 POST http://localhost:8080/user/add Content-Type: application/json { "email": "[email protected]","username": "ekko","password": "ekko" } ### 修改 PUT http://localhost:8080/user/update Content-Type: application/json { "id": 1,"email": "[email protected]","password": "root" } ### 獲取所有 GET http://localhost:8080/user/all Accept: */* Cache-Control: no-cache ### 刪除 PUT http://localhost:8080/user/del/2 ### 獲取所有 GET http://localhost:8080/user/all Accept: */* Cache-Control: no-cache
左上角 Run all ...
測試結果....
程式碼地址
https://github.com/Gleans/spring-boot/tree/master/springboot-jpa
到此這篇關於Spring Boot2.x整合JPA快速開發的文章就介紹到這了,更多相關Spring Boot2.x整合JPA快速開發內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!