Spring Data Jpa (四)注解式查询方法

详细讲解声明式的查询方法

1 @Query详解

  使用命名查询为实体声明查询是一种有效的方法,对于少量查询很有效。一般只需要关心@Query里面的value和nativeQuery的值。使用声明式JPQL查询有一个好处,就是启动的时候就知道语法正确与否。

  声明一个注解在Repository的查询方法上。

  

  Like查询,注意firstname不会自动加上%关键字

  直接用原始SQL。

  nativeQuery不支持直接Sort的参数查询

   错误方式:

   正确方式:

 [email protected]排序

  @Query在JPQL下想实现排序,直接用PageRequest或者直接用Sort参数都可以。

  在排序实例中实际使用的属性需要与实体模型里面的字段相匹配,这意味着它们需要解析为查询中使用的属性或别名。这是一个state_field_path_expression JPQL定义,并且Sort的对象支持一些特定的函数。

 [email protected]分页

  直接用Page对象接收接口,参数直接用Pageable的实现类即可。

  

[email protected]用法

  默认情况下,参数是通过顺序绑定在查询语句上的。这使得查询方法对参数位置的重构容易出错。为了解决这个问题,你可以使用@Param注解指定方法参数的具体名称,通过绑定的参数名字做查询条件。

  根据参数进行查询。

  

3.SpEL表达式的支持

  在Spring Data JPA 1.4以后,支持在@Query中使用SpEL表达式(简介)来接收变量。

  SpEL支持的变量如表4-1所示

  

  在以下的例子中,我们在查询语句中插入表达式:

  

  这个SpEL的支持比较适合自定义的Repository,如果想写一个通用的Repository接口,那么可以用这个表达式来处理:

  

4. @Modifying修改查询

  可以通过在@Modifying注解实现只需要参数绑定的update查询执行:

  

  简单地针对某些特定属性的更新也可以直接用基类里面提供的通用save。还有第三种方法,就是自定义Repository,使用EntityManager来进行更新操作。用法如下:

  

5 @QueryHints

  有很多数据库支持Hint Query的语法,不过这种查询支持比较老旧,感觉应该会慢慢被淘汰,工作中很少有人使用。Spring Data JPA还是做了很好的支持,它只支持一些固定的HintValue值,用来优化Query的作用。有两个注解需要了解和知道一下@QueryHints,value等于多个@QueryHint。

  用法如下:

  

6 @Procedure储存过程的查询方法

  我们通过@Procedure来介绍一下JPA对储存过程的支持

  (1)@Procedure源码如下:

    

  (2)首先创建一个储存过程名字plus1inout,有两个参数、两个结果。

 (3)使用@NamedStoredProcedureQueries注释来调用存储过程。这个必须定义在一个实体上面。

  

  关键要点:

    存储过程使用了注释@NamedStoredProcedureQuery,并绑定到一个JPA表。

    procedureName是存储过程的名字。

    name是JPA中存储过程的名字。

    使用注释@StoredProcedureParameter来定义存储过程使用的IN/OUT参数。

(4)直接通过自定义过的Repository完成储存过程的调用。

  

  关键要点:
    @Procedure的procedureName参数必须匹配
    @NamedStoredProcedureQuery的procedureName。
    @Procedure的name参数必须匹配@NamedStoredProcedureQuery的name。
    @Param必须匹配@StoredProcedureParameter注释的name参数。
    返回类型必须匹配:in_only_test存储过程返回是void,in_and_out_test存储过程必须返回String

7 @NamedQueries预定义查询

  在@Entity下增加@NamedQuery定义

  

   需要注意,query里面的值也是JPQL。查询参数也要和实体对应起来。因为实际场景中这种破坏Entity的侵入式很不美,也不方便,所以这种方式容易遗忘,工作中也很少推荐。 

  与之相对应的还有@NamedNativeQuery。用法一样,唯一不一样的是,query里面放置的是原生SQL语句,而非实体的字段名字

原文地址:https://www.cnblogs.com/youqc/p/11097574.html

时间: 2024-08-28 17:28:58

Spring Data Jpa (四)注解式查询方法的相关文章

Spring data jpa 实现简单动态查询的通用Specification方法

本篇前提: SpringBoot中使用Spring Data Jpa 实现简单的动态查询的两种方法 这篇文章中的第二种方法 实现Specification 这块的方法 只适用于一个对象针对某一个固定字段查询,下面通过泛型改写了这个方法: import java.util.List; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import j

Spring Data JPA 的 Specifications动态查询

主要的结构: 有时我们在查询某个实体的时候,给定的条件是不固定的,这时就需要动态构建相应的查询语句,在Spring Data JPA中可以通过JpaSpecificationExecutor接口查询.相比JPQL,其优势是类型安全,更加的面向对象. import java.util.List; import org.springframework.data.domain.Page; import org.springframework.data.domain.Pageable; import o

Spring Data JPA 常用注解 @Query、@NamedQuery

1.@Transient @Transient表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性:如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则ORM框架默认其注解为@Basic: //表示该字段在数据库表中没有 @Transientpublic int getAge() { return 1+1;} Jackson相关: 2.@JsonIgnoreProperties 此注解是类注解,作用是json序列化时将Javabean中的一些属性忽略掉,序列

模糊查询:Spring Data JPA 如何进行模糊查询(LIKE) ?

原文详见----->  https://blog.csdn.net/czx1204/article/details/79131281 一. 方法一 1.  Controller层: 方法参数如下,一定要加 "%"+name+"%" /** * @description: * @author: 程志祥<[email protected]com> * @date: 2018/1/22 下午5:15 * @version: V1.0 */ @RestCo

spring data jpa @Query注解中delete语句报错

项目中需要删除掉表中的一些数据 @Query("delete from EngineerServices es where es.engineerId = ?1") int deleteByEgId(String engineerId); 但是提示了错误 org.hibernate.hql.QueryExecutionRequestException: Not supported for DML operations 通过查阅相关的资料发现,对于执行update和delete语句需要添

Spring data Jpa,Mybatis,读写锁,@Lock 使用

Spring data jpa 支持注解式的读写锁(悲观锁),实际上这个东西硬编码也简单,但是基于Jpa 命名方式定义的Sql,只能用注解添加支持读写锁了, 不了解读写锁的可以点这里 mysql读写锁及事务 并且推荐 PESSIMISTIC_READ,PESSIMISTIC_WRITE,而不是 READ,WRITE,但是官方文档貌似没有更新这个案例,踩了一些坑. 新建一个实体Book.java /** * User: laizhenwei * Date: 2018-04-18 Time: 9:0

Spring Data JPA、 MyBatis与Hibernate简单对比

整体参考: https://blog.csdn.net/xihuanyuye/article/details/81201441 详细参考: https://blog.csdn.net/qq897958555/article/details/53208002 1.Spring Data JPA与Hibernate Spring Data JPA是Spring Data的子模块.使用Spring Data,使得基于“repositories”概念的JPA实现更简单和容易.Spring Data JP

Spring Data JPA 和MyBatis比较

两种框架自己都用过一段时间,现在想总结一下各自适用的场景,部分比较取自群友分享 框架简介 Spring Data JPA是Spring Data的子模块.使用Spring Data,使得基于“repositories”概念的JPA实现更简单和容易.Spring Data JPA的目标是大大简化数据访问层代码的编码.作为使用者,我们只需要编写自己的repository接口,接口中包含一些个性化的查询方法,Spring Data JPA将自动实现查询方法.JPA默认使用hibernate作为ORM实

spring boot系列(五)spring boot 配置spring data jpa (查询方法)

接着上面spring boot系列(四)spring boot 配置spring data jpa 保存修改方法继续做查询的测试: 1 创建UserInfo实体类,代码和https://www.cnblogs.com/kxm87/p/9273555.html中的一样. 2 创建数据库操作类相当于dao层,主要创建一个接口UserRepository,继承JpaRepository接口即可.本代码中主要都是自定义方法. 使用findXX 或者countXX(这两个不用编写sql,jpa会自动生成)