一、JPA:
JPA是Java Persistence API的简称,由sun公司提出的ORM规范,具体实现由各个ORM框架(Hibernate,oplink)去实现,统一了ORM框架的使用,开发人员更容易切换和学习ORM框架。
二、Spring Data:
是一个用于简化数据库访问,并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷,并支持map-reduce框架和云计算数据服务。 Spring Data 包含多个子项目包括JPA Hadoop 等
三、Spring Data JPA:
Spring Data其中的一个项目,整合JPA的使用,实现了基本的增删改查,分页的操作。关系图如下:
JpaRepository自带的查询方法:
查询方法 | jpa方法名 | 返回 |
全查询 | findAll() | list集合 |
主键查询 | findById() | Optional< UserEntity>实体对象 |
自定义条件查询 | findByNameAndPassword(String name, Long password) | UserEntity实体 |
自定义模糊查询 | findByNameLike("%"+name+"%") | list集合 |
自定义查询 | 需要在jpa中声明自定义的方法,确保命名规范! | 可自定义 |
四、在spring data jpa中有4种查询方式:
1、@Query注解查询
- 简介:在dao中增加接口方法并在方法上增加@Query注解并在注解中写hql语句来进行查询
- 示例:
public interface TestDao extends JpaRepository<Test, Long> {
@Query("select t from Test t where t.name = :keyWord")
List<Test> findTest(@Param("keyWord") String keyWord);
}
@Query参数说明:
名称 | 简介 |
value | 指定JPQL语句,当nativeQuery=true时是原生的sql语句 |
countQuery | 指定count的JPQL语句,不指定则自动生成,当nativeQuery=true时是原生的sql语句 |
countProjection | 依据哪个字段来count一般默认即可 |
nativeQuery | 默认是false,表示value 里面是不是原生的Sql 语句 |
name | 指定一个query 的名字,必须是唯一的。 如果不指定,默认的生成规则是: |
countName | 指定一个count 的query 名字,必须是唯一的。如果不指定,默认的生成规则是: |
2、自定义简单查询
- 简介:在dao中增加接口方法,并按照spring data jpa支持的模式命名方法,spring data jpa会按照指定规则生成sql语句
- 示例:
public interface TestDao extends JpaRepository<Test, Long> {
List<Test> findByKeyword(String keyword);
}
3、通过Example查询
- 简介:JpaRepository接口中包含了QueryByExampleExecutor,这个接口支持将实体作为参考进行查询
- 示例:
//service中(前提是testDao继承了JpaRepository接口)
public List<Test> findTests() {
Test test = new Test();
test.setName("aaa");
return testDao.findAll(Example.of(test));
}
- 注意事项:实体中只要有值的内容都会被放进查询条件中,若实体中包含基础类型例如int 就会以0进行匹配。
五、查询结果格式
1、Entity-List 使用默认形式即可
2、Map-List
- 注意:其中as name必须写,不写则map中key为下标。
@Query("select new map(t.name as name,t.value as value) from Test t where t.name = :keyWord")
List<Map<String,Object>> findTest(@Param("keyWord") String keyWord);
3、Vo-List
- 注意:与Map类似,使用构造方法的形式进行初始化,传入顺序必须与构造函数顺序一致
@Query("select new TestVo(t.name as name,t.value as value) from Test t where t.name = :keyWord")
List<TestVo> findTest(@Param("keyWord") String keyWord);
4、Projection-List
- 注意:TestProjection为接口,有对应的get方法,这种模式就不需要使用new的方式传值,支持@value注解来指定getAll的数据来源。
@Query("select t.name as name,t.value as value from Test t where t.name = :keyWord")
List<TestProjection> findTest(@Param("keyWord") String keyWord);
public interface TestProjection{
@Value("#{target.name+ '-' + target.value}")
String getAll();
String getName();
String getValue();
}
六、排序
- 静态排序:直接在jpql语句中直接写就可以了
- 参数排序:
- JpaSort.unsafe("排序规则"):会把排序语句直接追加到sql之后,当排序规则不单纯是属性而是需要进行一定处理时使用,例如:length(属性名)
- Sort.by("属性名") :会进行安全检查,属性名必须是实体中属性
@Query("select t.name as name,t.value as value from Test t where t.name = :keyWord")
List<TestProjection> findTest(@Param("keyWord") String keyWord,Sort sort);
//service中
List<TestProjection>findTest(String keyWord,String prop){
testdao.findTest(keyWord,Sort.by(prop))
}
七、分页
在dao方法中增加Pageable pageable参数即可 org.springframework.data.domain.Pageable
@Query("select t from Test t where t.name = :keyWord")
Page<Test> findTest(@Param("keyWord") String keyWord,Pageable pageable);