本文展示如何通過JPA訪問MySQL數據庫。
JPA全稱Java Persistence API,即Java持久化API,它爲Java開發人員提供了一種對象/關係映射工具來管理Java應用中的關係數據,結合其他ORM的使用,能達到簡化開發流程的目的,使開發者能夠專注於實現自己的業務邏輯上。
Spring boot結合Jpa 能夠簡化創建 JPA 數據訪問層和跨存儲的持久層功能,用戶的持久層Dao接口只需要繼承定義好的接口,無需再寫實現類,就可以實現對象的CRUD操作以及分頁排序等功能。
環境要求
- Mysql數據庫5.6以上
- JDK1.8以上
- 開發工具使用STS/eclipse
創建項目
選擇web和JPA依賴
添加MySQL數據庫驅動依賴
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
application.properties中配置數據庫連接信息
spring.jpa.hibernate.ddl-auto=create
spring.datasource.url=jdbc:mysql://localhost:3306/db_example
spring.datasource.username=springuser
spring.datasource.password=ThePassword
以上數據庫連接信息根據實際情況進行調整。
注意pring.jpa.hibernate.ddl-auto的值可以是none、create、update、create-drop。具體參考hibernate的文檔。
創建實體模型
com.yuny.jpademo.pojo.User
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
@Entity // This tells Hibernate to make a table out of this class
public class User {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private Integer id;
private String name;
private String email;
//此處省略get和set
}
增加數據訪問接口
com.yuny.jpademo.repository.UserRepository
public interface UserRepository extends PagingAndSortingRepository<User, Long> {
}
此接口會自動由spring實現,並且產生對應的實例放在容器中,該實例的名稱爲類名首字母小寫userRepository。
創建Controller測試
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import com.yuny.jpademo.pojo.User;
import com.yuny.jpademo.repository.UserRepository;
@RestController
public class UserController {
@Autowired
private UserRepository userRepository;
//測試插入新的數據
@GetMapping(path="/add")
public @ResponseBody String addNewUser (@RequestParam String name
, @RequestParam String email) {
User n = new User();
n.setName(name);
n.setEmail(email);
userRepository.save(n);
return "保存成功";
}
//測試獲取全部的數據
@GetMapping(path="/all")
public Iterable<User> getAllUsers() {
return userRepository.findAll();
}
}
測試
運行SpringBootJpademoApplication後,訪問增加數據的時候要傳參數:
http://localhost:8080/add?name=ffff&email=dddddd測試。結果如下:
數據庫顯示插入數據成功
訪問http://localhost:8080/all 測試
總結
在沒用使用jpa支持的時候,我們的代碼要定義IUserDao(持久層接口)、IUserDaoImpl(持久層實現類)、IUserService(業務層接口)等,這樣每寫一個實體類,都要衍生出多個類來進行操作。
而在Spring boot 中使用JPA,只需要聲明一個接口就可以了。
有一個很重要的問題,重新把Appliaction跑起來之後,你之前存的數據就沒了,數據庫被清空了,解決辦法是在數據庫配置文件加一句配置:
spring.jpa.hibernate.ddl-auto=update