• SpringDataJPA-@Query


    @Query注解

    使用@Query注解自定义查询

    @Retention(RetentionPolicy.RUNTIME)
    @Target({ElementType.METHOD, ElementType.ANNOTATION_TYPE})
    @QueryAnnotation
    @Documented
    public @interface Query {
        String value() default "";//sql 或者JPQL
    	//指定count的查询语句,不指定会根据query自动生成
        String countQuery() default "";
    	//指定使用什么字段来count()
        String countProjection() default "";
    	//标记是否用原生sql
        boolean nativeQuery() default false;
    	//指定一个query的名字,必须唯一
        String name() default "";
    	//指定一个count的query的名字,必须唯一
        String countName() default "";
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    @Query注解里使用原生sql动态查询,获取分组统计后时间最新的数据

    需求:联表查询,并且根据idj进行分组统计,并获取时间最新的一条数据,传入的参数有的肯为空
    解决:
    1.对时间使用MAX函数,分组后自然就会获取时间最新的记录
    2.使用if函数过滤参数为null的情况

    @Query(nativeQuery = true, value = "SELECT b.id," +
                "b.title," +
                "SUM(a.total_count) AS totalCount," +
                "SUM(a.negative_count) AS negativeCount," +
                "b.start_time,b.endtime," +
                "a.test_count AS testCount,MAX(a.analysis_date), " +
                " FROM result a ,config b " +
                " WHERE a.id=b.id AND b.id=?1 " +
                //" AND a.analysis_date BETWEEN ?2 AND ?3 AND a.code=?4 AND a.key=?5 " +
                " AND  if(?2 is null,1=1,a.analysis_date>=?2 ) AND a.analysis_date<=?3 AND a.code=?4 AND a.key=?5 " +
                " GROUP BY b.id")
        List<Map<String, Object>> search(@Param("id") Long id, @Param("start") String start, @Param("end") String end, @Param("code") String code, @Param("key") String key);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    原生sql分页查询

    返回整个表字段时才能使用表的实体来接收,自定义返回哪些字段时可以用Map或者Object[]来接收

    第1种 /* #pageable# */ ,这个参数必须要有

    这个方式分页有些问题

    @Query(nativeQuery = true,
        value = "SELECT * FROM works a WHERE if(?1 IS NULL,1=1,a.id=?1) AND a.delete_flag=0 /* #pageable# */ ",
        countQuery = "select count(*) from trsom_collected_works a WHERE if(?1 IS NULL,1=1,a.product_id=?1) AND a.delete_flag=0")
        
    
    • 1
    • 2
    • 3
    • 4

    第2种 直接用分页参数Pageable

     @Query(nativeQuery = true,value = "SELECT * FROM works a WHERE if(?1 IS NULL,1=1,a.id=?1) AND a.deleted=0")
        Page<WorksEntity> pageByTest1(@Param("id") Long id, Pageable pageable);
       或者使用Page<Map<String,Object>>来接收
       Page<Map<String,Object>> pageByTest2(@Param("id") Long id, Pageable pageable);
        
    
    • 1
    • 2
    • 3
    • 4
    • 5

    JPQL查询

    1. 使用JPQL直接操作实体写sql
    2. 可以直接使用分页参数 Pageable进行分页查询
     @Query(value = "select u from WorksEntity u where u.id=?1 and u.deleted=0")
     @Query(value = "select u from WorksEntity u where u.id=:id and u.deleted=0")
        Page<WorksEntity> pageById(@Param("id") Long id, Pageable pageable);
    
    
    • 1
    • 2
    • 3
    • 4
  • 相关阅读:
    全国大学生数学建模竞赛b题
    汽车区域控制器的关键技术和MCU解决方案深度分析
    排序。。。。
    什么是学习能力?如何提高学习能力?
    Codeforces 167B 状态设置的优化
    离散数学 --- 根树,根数的遍历,最优树和哈夫曼算法
    VTK未引用报错
    java毕业设计选题基于SSM毕业设计管理系统|毕设管理文档成绩Shiro
    太可怕啦!我在网上发了个贴,就被GPT-4推断出了个人隐私!GPT-4化身福尔摩斯
    Mysql_Note4
  • 原文地址:https://blog.csdn.net/qq_40605018/article/details/126366694