在实际开发过程当中,对数据库的操做无非就“增删改查”。就最为广泛的单表操做而言,除了表和字段不一样外,语句都是相似的,开发人员须要写大量相似而枯燥的语句来完成业务逻辑。html
为了解决这些大量枯燥的数据操做语句,咱们第一个想到的是使用ORM框架,好比:Hibernate。经过整合Hibernate以后,咱们以操做Java实体的方式最终将数据改变映射到数据库表中。java
为了解决抽象各个Java实体基本的“增删改查”操做,咱们一般会以泛型的方式封装一个模板Dao来进行抽象简化,可是这样依然不是很方便,咱们须要针对每一个实体编写一个继承自泛型模板Dao的接口,再编写该接口的实现。虽然一些基础的数据访问已经能够获得很好的复用,可是在代码结构上针对每一个实体都会有一堆Dao的接口和实现。mysql
因为模板Dao的实现,使得这些具体实体的Dao层已经变的很是“薄”,有一些具体实体的Dao实现可能彻底就是对模板Dao的简单代理,而且每每这样的实现类可能会出如今不少实体上。Spring-data-jpa的出现正可让这样一个已经很“薄”的数据访问层变成只是一层接口的编写方式。好比,下面的例子:spring
public interface UserRepository extends JpaRepository<User, Long> { User findByName(String name); @Query("from User u where u.name=:name") User findUser(@Param("name") String name); }
咱们只须要经过编写一个继承自JpaRepository
的接口就能完成数据访问,下面以一个具体实例来体验Spring-data-jpa给咱们带来的强大功能。sql
因为Spring-data-jpa依赖于Hibernate。若是您对Hibernate有必定了解,下面内容能够绝不费力的看懂并上手使用Spring-data-jpa。若是您仍是Hibernate新手,您能够先按以下方式入门,再建议回头学习一下Hibernate以帮助这部分的理解和进一步使用。数据库
在pom.xml
中添加相关依赖,加入如下内容:springboot
<dependency <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency>
在application.xml
中配置:数据库链接信息(如使用嵌入式数据库则不须要)、自动建立表结构的设置,例如使用mysql的状况以下:服务器
spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.jpa.properties.hibernate.hbm2ddl.auto=create-drop
spring.jpa.properties.hibernate.hbm2ddl.auto
是hibernate的配置属性,其主要做用是:自动建立、更新、验证数据库表结构。该参数的几种配置以下:session
create
:每次加载hibernate时都会删除上一次的生成的表,而后根据你的model类再从新来生成新表,哪怕两次没有任何改变也要这样执行,这就是致使数据库表数据丢失的一个重要缘由。create-drop
:每次加载hibernate时根据model类生成表,可是sessionFactory一关闭,表就自动删除。update
:最经常使用的属性,第一次加载hibernate时根据model类会自动创建起表的结构(前提是先创建好数据库),之后加载hibernate时根据model类自动更新表结构,即便表结构改变了但表中的行仍然存在不会删除之前的行。要注意的是当部署到服务器后,表结构是不会被立刻创建起来的,是要等应用第一次运行起来后才会。validate
:每次加载hibernate时,验证建立数据库表结构,只会和数据库中的表进行比较,不会建立新表,可是会插入新值。至此已经完成基础配置,若是您有在Spring下整合使用过它的话,相信你已经感觉到Spring Boot的便利之处:JPA的传统配置在persistence.xml
文件中,可是这里咱们不须要。固然,最好在构建项目时候按照以前提过的最佳实践的工程结构来组织,这样以确保各类配置都能被框架扫描到。app