本文目錄
一、JPA介紹二、Spring Data JPA類結構圖1、類的結構關係圖三、程式碼實現1、新增對應的Starter2、新增連線資料庫的配置3、主要程式碼
一、JPA介紹
JPA是Java Persistence API的簡稱,中文名Java持久層API,是JDK 5.0註解或XML描述物件-關係表的對映關係,並將執行期的實體物件持久化到資料庫中。
SpringData是Spring的一個子專案。用於簡化資料庫訪問,支援NoSQL和關係資料儲存,其主要目標是使資料庫的訪問變得方便快捷。
Spring Data JPA致力於減少資料訪問層(DAO)的開發量,開發者唯一要做的就只是宣告持久層的介面,其他都交給Spring Data JPA 來幫你完成!
二、Spring Data JPA類結構圖
1、類的結構關係圖
三、程式碼實現
1、新增對應的Starter
pom.xml中新增下面依賴
<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>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
2、新增連線資料庫的配置
#修改tomcat預設埠號
server.port=8090
#配置資料來源資訊
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://192.168.0.1:3306/test
spring.datasource.username=root
spring.datasource.password=123456
#配置jpa
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
spring.jackson.serialization.indent_output=true
3、主要程式碼
UserRepository.java
/**
* 注意:
* 1.這裡這裡是interface,不是class
* 2.CrudRepository裡面的泛型,第一個是實體類,第二個是主鍵的型別
*/
public interface UserRepository extends CrudRepository<User, Integer> {
@Query("from User where id =:id ")
public User getUser(@Param("id") Integer id);
}
User.java
@Entity
@Table(name = "user")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer id;
private String name;
private String password;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
UserController.java
@RestController
public class UserController {
@Autowired
UserService service;
/**
* 根據id 查詢
*/
@RequestMapping("/getUser/{id}")
public User getUser(@PathVariable("id") Integer id) {
return service.getUser(id);
}
/**
* 根據id 刪除
*/
@RequestMapping("/deleteUser/{id}")
public String deleteUser(@PathVariable("id") Integer id) {
service.deleteUser(id);
return "刪除成功!";
}
}
user表資料截圖如下:
專案啟動成功後訪問http://localhost:8090/getUser/2和http://localhost:8090/deleteUser/2後截圖如下:
到此傳送Spring Boot整合JPA全部實現,有問題歡迎留言溝通哦!
完整原始碼地址: https://github.com/suisui2019/springboot-study
推薦閱讀
1.Spring Boot 2.X 整合Redis
2.Spring Boot 2.X 如何優雅的解決跨域問題?
3.Spring Boot 2.X 整合spring session實現session共享
4.Spring條件註解@Conditional
5.SpringBoot 2.X從0到1實現郵件傳送功能
6.Redis批量刪除key的小技巧,你知道嗎?
限時領取免費Java相關資料,涵蓋了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo/Kafka、Hadoop、Hbase、Flink等高併發分散式、大資料、機器學習等技術。
關注下方公眾號即可免費領取: