1. 程式人生 > 程式設計 >Spring Boot2.x整合JPA快速開發的示例程式碼

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/ 初始化一個專案

Spring Boot2.x整合JPA快速開發的示例程式碼

這裡使用的是Maven,下載之後請在IDEA匯入專案

專案結構圖

Spring Boot2.x整合JPA快速開發的示例程式碼

先看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> {

}

Spring Boot2.x整合JPA快速開發的示例程式碼

配置檔案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));
  }

}

測試輸出

Spring Boot2.x整合JPA快速開發的示例程式碼

常見異常

如果出現下列等錯誤:

Error:(41,13) java: 找不到符號
符號: 方法 setName(java.lang.String)
位置: 型別為com.example.springbootjpademo.entity.User的變數 user

請注意下面的設定是否正確:

Spring Boot2.x整合JPA快速開發的示例程式碼

RestClient API 測試

Spring Boot2.x整合JPA快速開發的示例程式碼

### 新增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 ...

測試結果....

Spring Boot2.x整合JPA快速開發的示例程式碼

程式碼地址

https://github.com/Gleans/spring-boot/tree/master/springboot-jpa

到此這篇關於Spring Boot2.x整合JPA快速開發的文章就介紹到這了,更多相關Spring Boot2.x整合JPA快速開發內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!