SpringDataJpa如何使用union多表分页条件查询

目录
  • 如何使用union多表分页条件查询
    • 条件
    • 分页
    • 踩过的坑
    • 分享几个用到的mysql语法
  • jpa执行原生sqlunionbug解决

如何使用union多表分页条件查询

当前项目有一个全局搜索的功能,需要涉及到7-8张主表,由于当前项目使用的是Jpa,所以我决定使用原生sql的方式使用union来进行查询,由于对这个框架的不熟悉,被坑了很久,特此记录。

条件

1、在参数列表中,使用@Param注解(例:@Param(“userId”) Long userId)

2、在sql中应该以 :userId 的方式来注入参数(例:person.user_id = :userId),或者用?1 ?2根据参数的顺序来注入也可以,我采用的是第一种

3、sql应该是写在@Query的value中,并且设置 nativeQuery = true

4、如果要设置一个可能为空的值,比如:有一个分类,需要当作条件查询,但是这个值是可能为空的,所以需要在sql中判断,如果为空就不进行筛选。语法其实和在sql中判断是一样的

where IF(:category is not null,a.category = :category is not null,1=1)

分页

1、分页必须加countQuery这个参数,把上面sql价格count就可以

2、传入Pageable,不要传sort,不然会报错,暂时没找到解决方案

例如 select * from a 为你的sql

那么分页应该是

select * from (select * from a) b order by ?#{#pageable}

order by在countQuery里面就不用加了哦

3、返回的是Page<Object[]>,里面content封装的顺序就是你sql查出来的顺序

踩过的坑

1、多表union查询,查询的字段应该是一样的,比如第一张user表查询id,name,sex、第二张address表也必须查询id,name,sex,如果没有这个字段则自己封装返回固定的值,可以为空字符串

2、传入pageable的时候 ?#{#pageable} 必须这样写

分享几个用到的mysql语法

1、判断是否为空,不为空查询时间在传入时间之间的数据

IF(:startTime is not null and :endTime is not null,proc.create_time between :startTime and :endTime,1=1)

这边我在service是判断了结束时间是否为空的,如果结束时间为空,开始时间不为空默认查询一年的数据

2、根据名称模糊查询

proc.content LIKE CONCAT('%',:content,'%')

3、最后根据查出来的总数据对类型筛选

IF(:category is not null,a.category = :category is not null,1=1)

小结一下:

1、其实很简单的分页条件查询,因为不熟悉jpa的语法,导致浪费了很多时间,希望可以帮到更多的人。

2、暂时不知道怎么排序,无论是在pageable中传入sort,还是在sql最后进行排序都会报错,如果有大佬知道的话可以点拨一下。

jpa执行原生sql union bug解决

@Query(value = "SELECT * FROM count_entity where id=-1111 union (SELECT * FROM count_entity where video_name = ?1 AND platform ='腾讯视频' ORDER BY click_date DESC LIMIT ?2)"
 + "UNION"
 + "(SELECT * FROM count_entity where video_name = ?1 AND platform ='爱奇艺' ORDER BY click_date DESC LIMIT ?2)"
 + "UNION"
 + "(SELECT * FROM count_entity where video_name = ?1 AND platform ='芒果TV' ORDER BY click_date DESC LIMIT ?2)", nativeQuery = true)

union前面需要连接一个空数据查询,因为union 第一个查询不能用()

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • Spring MVC结合Spring Data JPA实现按条件查询和分页

    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下 推荐视频:尚硅谷Spring Data JPA视频教程,一学就会,百度一下就有. 后台代码:在DAO层继承Spring Data JPA的PagingAndSortingRepository接口实现的 (实现方法主要在SbglServiceImpl.java类中) 前台表现:用kkpaper表现出来 实现效果: 1.实体类 package com.jinhetech.yogurt.sbgl.entity; im

  • Spring Data JPA带条件分页查询实现原理

    最新Spring Data JPA官方参考手册 Version 2.0.0.RC2,2017-07-25 https://docs.spring.io/spring-data/jpa/docs/2.0.0.RC2/reference/html/ JPA参考手册 (找了半天, 在线版的只找到这个) https://www.objectdb.com/java/jpa Spring Data JPA的Specification类, 是按照Eric Evans的<领域驱动设计>书中Specificat

  • Spring Data JPA 复杂/多条件组合分页查询

    话不多说,请看代码: public Map<String, Object> getWeeklyBySearch(final Map<String, String> serArgs, String pageNum, String pageSize) throws Exception { // TODO Auto-generated method stub Map<String,Object> resultMap=new HashMap<String, Object&

  • Spring Data JPA 实现多表关联查询的示例代码

    多表查询在spring data jpa中有两种实现方式,第一种是利用hibernate的级联查询来实现,第二种是创建一个结果集的接口来接收连表查询后的结果,这里介绍第二种方式. 一.一对一映射 实体 UserInfo :用户. 实体 Address:家庭住址. 这里通过外键的方式(一个实体通过外键关联到另一个实体的主键)来实现一对一关联. 实体类 1.实体类 UserInfo.java package com.johnfnash.learn.domain; import java.io.Ser

  • SpringDataJpa如何使用union多表分页条件查询

    目录 如何使用union多表分页条件查询 条件 分页 踩过的坑 分享几个用到的mysql语法 jpa执行原生sqlunionbug解决 如何使用union多表分页条件查询 当前项目有一个全局搜索的功能,需要涉及到7-8张主表,由于当前项目使用的是Jpa,所以我决定使用原生sql的方式使用union来进行查询,由于对这个框架的不熟悉,被坑了很久,特此记录. 条件 1.在参数列表中,使用@Param注解(例:@Param(“userId”) Long userId) 2.在sql中应该以 :user

  • mybatis-plus实现自定义SQL、多表查询与多表分页查询语句实例

    目录 前言 1.自定义SQL 2.多表查询 3.多表分页查询 4.多表分页条件查询 总结 前言 本文介绍了在mybatis-plus中如何实现:自定义SQL语句,多表查询语句,多表分页查询语句 在说怎么实现之前我们要先明白一个概念,就是mybatis-plus是在mybatis的基础上进行增强,并不做改变,所以mybatis的操作在mybatis-plus中也是一样可以使用的,咱们直接上代码 1.自定义SQL 在mapper中自定义一个方法即可 @Repository public interf

  • Springboot+Mybatis实现分页加条件查询功能

    本文实例为大家分享了Springboot+Mybatis实现分页加条件查询的具体代码,供大家参考,具体内容如下 User.xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"         "http://mybatis.org/dtd/mybatis-3-mapp

  • 记录一个C++在条件查询时遇到的问题(推荐)

    C++在条件查询时困扰了6个小时的小问题 先说结论1. 贴上运行错误的原码2. 错误分析2.1 sql语句错误2.2 sql语句替换2.3 继续问题分析 3.总结 先说结论 1:如果由%作为占位符.arg()传参的模式,则sql_query.exec(sql_str)执行查询时,必须加上查询语句. 2:如果由?作为占位符.addBindValue()传参的模式,则sql_query.exec()执行查询时,不可加上查询语句. 1. 贴上运行错误的原码 int InputManage::query

  • asp.net实现的MVC跨数据库多表联合动态条件查询功能示例

    本文实例讲述了asp.net实现的MVC跨数据库多表联合动态条件查询功能.分享给大家供大家参考,具体如下: 一.控制器中方法 [HttpGet] public ActionResult Search() { ViewBag.HeadTitle = "搜索"; ViewBag.MetaKey = "\"123\""; ViewBag.MetaDes = "\"456\""; string whereText

  • MSSQL分页存储过程完整示例(支持多表分页存储)

    本文实例讲述了MSSQL分页存储过程.分享给大家供大家参考,具体如下: USE [DB_Common] GO /****** 对象: StoredProcedure [dbo].[Com_Pagination] 脚本日期: 03/09/2012 23:46:20 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO /************************************************************

  • PHP CodeIgniter分页实例及多条件查询解决方案(推荐)

    最近在用CI框架的时候,用了CI的分页类,以前是用前端整分页,这次干脆用用框架自带的,自己这个健忘的脑袋,还是记录一下吧. 因为页面中有条件筛选的表单,所以想要完成的效果就是,输入条件后,分页跳转之后能维持所输入的条件.想了一下,自己的思路如下代码吧. controller 代码 class Monitors extends CI_Controller { public function warning(){ $config= array(); $config['per_page'] = 15;

  • 一个可查询所有表的“通用”查询分页类

    一个可查询所有表的"通用"查询分页类 最近突发奇想,希望写出一个可以针对所有表的查询分页类.因为在实际的开发中,恐怕查询并将结果集分页显示是用得最多的代码,而表的结构是多样的,我想尽可能地提高代码的重用率和维护性. 以下是我写的,请各位加以指点,测试,看能否进行更好的改进和更多的支持. 目前还只支持单一的表,不支持联合查询.但未来可以会考虑如何支持. 代码: <?php /******************************************************

  • 基于Mybatis Plus实现多表分页查询的示例代码

    注意:Mybatis Plus 3.0.7 版本才开始用[自定义sql]+[QueryWrapper],低版本不能使用,还是老实写SQL进行条件拼接 1.源码分析 在Wrapper<T>接口中就有如下方法 /** * 获取自定义SQL 简化自定义XML复杂情况 * 使用方法:自定义sql + ${ew.customSqlSegment} * 1.逻辑删除需要自己拼接条件 (之前自定义也同样) * 2.不支持wrapper中附带实体的情况 (wrapper自带实体会更麻烦) * 3.用法 ${e

随机推荐