本文展现如何经过JPA访问MySQL数据库。java
JPA全称Java Persistence API,即Java持久化API,它为Java开发人员提供了一种对象/关系映射工具来管理Java应用中的关系数据,结合其余ORM的使用,能达到简化开发流程的目的,使开发者可以专一于实现本身的业务逻辑上。mysql
Spring boot结合Jpa 可以简化建立 JPA 数据访问层和跨存储的持久层功能,用户的持久层Dao接口只须要继承定义好的接口,无需再写实现类,就能够实现对象的CRUD操做以及分页排序等功能。git
使用STS建立项目github
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency>
spring.jpa.hibernate.ddl-auto=create
spring.datasource.url=jdbc:mysql://localhost:3306/db_example
spring.datasource.username=springuser
spring.datasource.password=ThePassword
以上数据库链接信息根据实际状况进行调整。web
注意pring.jpa.hibernate.ddl-auto的值能够是none、create、update、create-drop。具体参考hibernate的文档。spring
com.yuny.jpademo.pojo.Usersql
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。app
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测试。结果以下:spring-boot
数据库显示插入数据成功
访问http://localhost:8080/all 测试
在没用使用jpa支持的时候,咱们的代码要定义IUserDao(持久层接口)、IUserDaoImpl(持久层实现类)、IUserService(业务层接口)等,这样每写一个实体类,都要衍生出多个类来进行操做。
而在Spring boot 中使用JPA,只须要声明一个接口就能够了。
案例代码
https://github.com/junyanghuang/spring-boot-samples/tree/master/spring-boot-jpademo