码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • SpringDataJPA-@Query


    SpringDataJpa

    • @Query注解
      • @Query注解里使用原生sql动态查询,获取分组统计后时间最新的数据
      • 原生sql分页查询
        • 第1种 /* #pageable# */ ,这个参数必须要有
        • 第2种 直接用分页参数Pageable
      • JPQL查询

    @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
  • 相关阅读:
    nmap保存到扫描文件(局域网)
    【项目】小帽课堂(一)
    dedecms织梦复制模型报错系统找不到你所指定的表
    SpringCloud微服务从入门到入土笔记(1/2)
    Workfine新手入门:数据规范之列表
    GitHub获120k+star的阿里内网“疯传”葵花宝典JVM虚拟机调优指南
    Centos7安装MySQL5.7全部流程
    node 第八天 使用前后端不分离的方式实现cookie登录验证
    美食自媒体应该拍摄,这些技巧肯定对你有帮助
    500行代码手写docker-以新命名空间运行程序
  • 原文地址:https://blog.csdn.net/qq_40605018/article/details/126366694
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号