我們在上一篇搭建了一個簡單的springboot應用,這一篇將介紹使用spring-data-jpa操作資料庫。 新建一個MySQL資料庫,這裡資料庫名為springboot,建立user_info數據表,作為我們示例操作的表對象。 user_info信息如下: 資料庫及表創建成功後,回到我們的工程 ...
springboot系列文章:http://www.javazhiyin.com/?tag=springboot
我們在上一篇搭建了一個簡單的springboot應用,這一篇將介紹使用spring-data-jpa操作資料庫。
新建一個MySQL資料庫,這裡資料庫名為springboot,建立user_info數據表,作為我們示例操作的表對象。
user_info信息如下:
DROP TABLE IF EXISTS `user_info`; CREATE TABLE `user_info` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(255) DEFAULT NULL, `password` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of user_info -- ---------------------------- INSERT INTO `user_info` VALUES ('1', 'Java之音', '12345'); INSERT INTO `user_info` VALUES ('2', '張無忌', '123');
資料庫及表創建成功後,回到我們的工程中
第零步,首先引入MySQL及jpa的maven依賴包:
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency>
第一步,在yml配置文件中配置資料庫連接信息:
spring: datasource: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=UTF-8&useSSL=false username: root password: 1011 jpa: show-sql: true
第二步,創建一個實體類,對應數據表實體映射:
package com.javazhiyin; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; /** * Created by 57783 on 2018/7/4. */ @Entity public class UserInfo { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Integer id; private String username; private String password; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public UserInfo(){ } }
第三步,創建一個Repository類,繼承JpaRepository類:
package com.javazhiyin; import org.springframework.data.jpa.repository.JpaRepository; /** * Created by 57783 on 2018/7/4. */ public interface UserInfoRepository extends JpaRepository<UserInfo,Integer>{ }
這裡繼承了JpaRepository類,其封裝了一些對資料庫操作的基本方法,我們通過源碼查看一下JpaRepository有哪些方法:
// // Source code recreated from a .class file by IntelliJ IDEA // (powered by Fernflower decompiler) // package org.springframework.data.repository; import java.util.Optional; @NoRepositoryBean public interface CrudRepository<T, ID> extends Repository<T, ID> { <S extends T> S save(S var1); <S extends T> Iterable<S> saveAll(Iterable<S> var1); Optional<T> findById(ID var1); boolean existsById(ID var1); Iterable<T> findAll(); Iterable<T> findAllById(Iterable<ID> var1); long count(); void deleteById(ID var1); void delete(T var1); void deleteAll(Iterable<? extends T> var1); void deleteAll(); }
第四步,新建一個Controller,實現對資料庫的增刪改查操作:
package com.javazhiyin; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import java.util.List; /** * Created by 57783 on 2018/7/4. */ @RestController public class UserInfoController { @Autowired private UserInfoRepository userInfoRepository; /** * 查 * @return */ @GetMapping(value = "/list") public List<UserInfo> getUserList(){ return userInfoRepository.findAll(); } /** * 增 * @param username * @param password * @return */ @PostMapping(value = "/addUser") public UserInfo addUser(@RequestParam("username") String username, @RequestParam("password") String password){ UserInfo user = new UserInfo(); user.setUsername(username); user.setPassword(password); return userInfoRepository.save(user); } /** * 改 * @param id * @param username * @param password * @return */ @PutMapping(value = "updUser/{id}") public UserInfo updUser(@PathVariable("id") Integer id, @RequestParam("username") String username, @RequestParam("password") String password){ UserInfo user = new UserInfo(); user.setId(id); user.setUsername(username); user.setPassword(password); return userInfoRepository.save(user); } /** * 刪 * @param id */ @DeleteMapping(value = "delUser/{id}") public void delUser(@PathVariable("id") Integer id){ UserInfo user = new UserInfo(); user.setId(id); userInfoRepository.delete(user); } }
測試上述代碼,這裡我們使用postman測試,非常方便:
查詢測試:
新增測試:
修改測試:
刪除測試:
- GenerationType.TABLE
- GenerationType.SEQUENCE
- GenerationType.IDENTITY
- GenerationType.AUTO
- Repository:最頂層的介面,是一個空的介面,目的是為了統一所有Repository的類型,且能讓組件掃描的時候自動識別。
- CrudRepository :是Repository的子介面,提供CRUD的功能
- PagingAndSortingRepository:是CrudRepository的子介面,添加分頁和排序的功能
- JpaRepository:是PagingAndSortingRepository的子介面,增加了一些實用的功能,比如:批量操作等。
- JpaSpecificationExecutor:用來做負責查詢的介面
- Specification:是Spring Data JPA提供的一個查詢規範,要做複雜的查詢,只需圍繞這個規範來設置查詢條件即可
本文可運行的源碼:https://github.com/javazhiyin/springboot/tree/master/bootdemo_01