1、JPA介紹2、Spring Data JPA類結構圖一、類的結構關係圖3、代碼實現一、添加對應的Starter二、添加鏈接數據庫的配置三、主要代碼html
JPA是Java Persistence API的簡稱,中文名Java持久層API,是JDK 5.0註解或XML描述對象-關係表的映射關係,並將運行期的實體對象持久化到數據庫中。
SpringData是Spring的一個子項目。用於簡化數據庫訪問,支持NoSQL和關係數據存儲,其主要目標是使數據庫的訪問變得方便快捷。
Spring Data JPA致力於減小數據訪問層(DAO)的開發量,開發者惟一要作的就只是聲明持久層的接口,其餘都交給Spring Data JPA 來幫你完成!java
pom.xml中添加下面依賴mysql
<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>
#修改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
UserRepository.javagit
/**
* 注意:
* 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.javagithub
@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.javaweb
@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表數據截圖以下:spring
項目啓動成功後訪問http://localhost:8090/getUser/2和http://localhost:8090/deleteUser/2後截圖以下:sql
到此發送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等高併發分佈式、大數據、機器學習等技術。
關注下方公衆號便可免費領取:
原文出處:https://www.cnblogs.com/haha12/p/11343168.html