java 多表分页_多表单独查询组合结果的自定义分页(java代码)

多表单独查询组合结果的自定义分页实现(java代码)

一、业务需求:

遇到一个业务,需要多个表进行分页查询,使用union联合查询时,速度极其缓慢,即使查询的字段添加了索引,union查询好像不走索引,因此联合查询无法满足需求。

二、解决思路:

想到一个解决方案,多个表进行单独查询(表查询字段添加索引就会快很多),根据分页参数查询需要的表中的数据,其他的表仅仅查询满足条件的数量值count返回累加,作为total分页使用。

三、代码实现:(纯手写)

PageInfopageInfo = null;

//1、根据查询时间获取存在的表

ListreList = getExitTablesByTime(startTime,endTime);

if(reList.isEmpty()){

return "不存在数据!";

}

PageCondition pageCondition = abcQuery.getPageCondition();

if(StringUtils.isEmpty(pageCondition)){

pageCondition = new PageCondition();

}

Integer pageSize = pageCondition.getPageSize();

Integer pageNum = pageCondition.getPageNumber();

Integer totalSize = pageSize;

Integer total = 0;

Integer startNum = pageCondition.getOffset();

Integer temp = pageSize*pageNum;

// abcQuery.setOrderBy("a.created desc");

/**

* 2、根据分页入参和表中数据的数量 确定查询的表

* 自定义查询的总量和list内容,构建pageInfo

*/

List list = new ArrayList();

String all_sql = " id, ....., " +

" .......... creator, modifier, " +

" status, created, modified ";

String count = " count(0) ";

for (int i = reList.size()-1; i >=0 ; i--) {

String tableName = reList.get(i);

String countsql = "select "+ count +" FROM "+ tableName +" a";

abcQuery.setUnitSql(countsql);

Integer tabletotal = abcMapper.findCount(abcQuery);

total += tabletotal;

if(list.size() == totalSize){

continue;

}

String listsql = "select "+ all_sql +" FROM "+ tableName +" a";

abcQuery.setUnitSql(listsql);

//一张表数据满足条件。

if(temp <= tabletotal){

abcQuery.setStartNum(startNum);

abcQuery.setPageSize(pageSize);

List templist = abcMapper.findList(abcQuery);

list.addAll(templist);

continue;

}

//一张表有部分数据满足条件。

if(startNum < tabletotal){

abcQuery.setStartNum(startNum);

abcQuery.setPageSize(pageSize);

List templist = abcMapper.findList(abcQuery);

list.addAll(templist);

startNum = startNum-tabletotal<0 ? 0 : startNum-tabletotal;

pageSize = pageSize - templist.size();

temp = startNum + pageSize;

continue;

}

//一张表没有数据满足条件。

if(startNum >= tabletotal){

startNum = startNum-tabletotal;

temp = startNum + pageSize;

continue;

}

}

pageInfo = new PageInfo(list);

pageInfo.setPageNum(pageNum);

pageInfo.setTotal(total);

结束,也可传入多条件查询,以上更多提供一种解决的思路。如有帮助,幸甚。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/397665.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Neutorn LBaaS 原理

Load Balance as a Service&#xff08;LBaaS&#xff09;是 Neutron 提供的一项高级网络服务。LBaaS 允许租户在自己的网络中创建和管理 load balancer。 load balancer 可以说是分布式系统中比较基础的组件。 它接收前端发来的请求&#xff0c;然后将请求按照某种均衡策略转发…

判断一个图中有无环路的存在

这里要引入两个概念&#xff1a; 1.树边&#xff1a;是一条未被遍历过的边&#xff0c;它指向一个未被访问过的点。 2.反向边&#xff1a;是一条未被遍历过的边&#xff0c;它指向一个被访问过的点。 如果图中有环路的存在&#xff0c;那么环路的最后一个边必然是一条反向边。 …

精选的一些《编程之美》相关资料

又要到一年的招聘季了&#xff0c;肯定又有很多人开始啃《编程之美》了吧。这本书从开阔视野的角度来说很好&#xff0c;不过限于篇幅&#xff0c;有的问题并没有讲清楚&#xff08;甚至问题叙述模棱两可、被标榜为“鼓励同面试官交流以获得更多细节”&#xff09;&#xff1b;…

java 内置函数_java8 四大内置核心函数式接口

其他补充接口&#xff1a;一、Consumer&#xff1a;消费型接口(void accept(T t))来看一个简单得例子&#xff1a;1 /**2 * 消费型接口Consumer3 */4 Test5 public void test1 () {6 consumo(500, (x) -> System.out.println(x));7 }89 public void consumo (double money, …

jQuery - (JQuery datatables api 使用解读)

学习可参考&#xff1a;http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/2006942 分别导入css和js文件 <link href"~/Content/bootstrap.css" rel"stylesheet" /> <link href"~/Content/datatab…

Tomcat配置JNDI数据源

经过3个多小时的努力&#xff0c;配置JNDI数据源(主要是通过DBCP连接池)终于搞定&#xff5e;还是Tomcat官方的说明好&#xff0c;不过全是英文的&#xff0c;大概还看得懂&#xff0e;百度上那么花花绿绿的太多了&#xff0c;一个也没成功&#xff01;&#xff0e;&#xff0e…

java 线程池 固定大小_使用Executors服务在Java中创建固定大小线程池的最佳方法...

查看源代码,您将意识到&#xff1a;Executors.newFixedThreadPool(threadPoolSize);相当于&#xff1a;return new ThreadPoolExecutor(threadPoolSize, threadPoolSize, 0L, MILLISECONDS,new LinkedBlockingQueue());由于它不提供显式的RejectedExecutionHandler,因此使用默认…

令牌验证 token

通过令牌验证在注册中心控制权限&#xff0c;以决定要不要下发令牌给消费者&#xff0c;可以防止消费者绕过注册中心访问提供者&#xff0c;另外通过注册中心可灵活改变授权方式&#xff0c;而不需修改或升级提供者。 可以全局设置开启令牌验证&#xff1a; <!--随机token令…

easybcd 支持 windows 10 和 ubuntu 14.04 双系统启动

家里计算机系统 windows 10 全新安装。 原本是双系统的&#xff0c;还有一个ubuntu。 windows 10 安装以后&#xff0c;恢复ubuntu就是问题了。 (事后经验&#xff1a;请不要立刻安装bcd修改工具) 最初的方法是利用easybcd修改bcd记录。操作是成功的&#xff0c;但系统重新启动…

需求分析与原型设计

结对者&#xff1a;031402140李严 0314026617林瑞斌 需求分析与原型设计 NABCD模型 N&#xff08;Need&#xff0c;需求&#xff09;: 收集信息的过程太过繁琐&#xff0c;有班级总负责人需汇总每一个同学的志愿并填入excel表中&#xff0c;上交年级负责人&#xff0c;年级负责…

java导出表格_java怎么导出excel表格

import com.spire.xls.ExcelVersion;import com.spire.xls.Workbook;import com.spire.xls.Worksheet;public class InsertArray {public static void main(String[] args) {//创建Workbook对象Workbook wb new Workbook();//获取第一张62616964757a686964616fe4b893e5b19e313…

for 循环 和 Array 数组对象

博客地址&#xff1a;https://ainyi.com/12 for 循环 和 Array 数组对象方法 for for-in for-of forEach效率比较 - 四种循环&#xff0c;遍历长度为 1000000 的数组叠加&#xff0c;得到的时间差&#xff1a;for 3for-in 250for-of 7forEach 44- 效率速度&#xff1a;for >…

IntelliJ IDEA---java的编译工具【转】

转自&#xff1a;http://baike.baidu.com/link?urlsEpS0rItaB9BiO3i-qCdGSYiTIVPSJfBTjSXXngtN2hBhGl1j36CYQORKrbpqMHqjvu3MOfkgVzpMqr8To2l2q IDEA 全称 IntelliJ IDEA&#xff0c;是java语言开发的集成环境&#xff0c;IntelliJ在业界被公认为最好的java开发工具之一&#…

OC中文件读取类(NSFileHandle)介绍和常用使用方法

NSFileHandle 1.NSFileManager类主要对于文件的操作(删除&#xff0c;修改&#xff0c;移动&#xff0c;赋值等等) //判断是否有 tagetPath 文件路径&#xff0c;没有就创建NSFileManager *fileManage [NSFileManager defaultManager];BOOL success [fileManage createFileAt…

java filereader读文件_Java FileReader读文件

import java.io.*;class FileReaderDemo{public static void main(String[] args) throws IOException{//创建一个文件读取流对象&#xff0c;和指定名称的文件相关联。//要保证该文件是已经存在的&#xff0c;如果不存在&#xff0c;会发生异常FileNotFoundExceptionFileReade…

struts2拦截器

struts拦截器 图&#xff1a; 1、拦截器是什么&#xff1f; 分离关注&#xff1a; 完成一个功能&#xff0c;可以写在一个类中&#xff0c;然后一个类中4个步骤&#xff0c;实现该类完成。 我们可以将4个步骤写在4个类中&#xff0c;然后每一个类完成一部分功能&#xff0c;然后…

Springboot-Jpa多数据库配置-2.0+版本

pom.xml增加: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId></dependency> 配置表同JdbcTemplate配置. 主数据源: ConfigurationEnableTransactionManagementEna…

Windows虚拟地址转物理地址(原理+源码实现,附简单小工具)

By Lthis 上个月就想写了&#xff0c;一直没时间...网上大概搜了一下&#xff0c;原理与操作倒是一大堆&#xff0c;一直没看到源码实现&#xff0c;总得有人动手&#xff0c;这回轮到我了。东西写得很烂&#xff0c;请大牛勿喷。一直觉得靠源码的方式驱动学习是非常好的一种学…

python装饰器的使用

借用装饰器&#xff0c;我们可以批量的对老的函数进行改造或扩展老函数功能&#xff0c;比如需要对函数的接收参数进行过滤&#xff0c;Flash的url路由功能就是使用的这个方式 def dropoushu(): # 这一层函数可以去掉&#xff0c;如果去掉了&#xff0c;则使用checkjiou这种方…

7_文件上传漏洞

文件上传漏洞 当文件上传时&#xff0c;若服务端脚本语言未对上传的文件进行严格验证和过滤&#xff0c;若恶意用户上传恶意的脚本文件时&#xff0c;就有可能控制整个网站甚至是服务器&#xff0c;这就是文件上传漏洞。 权限 1.网站后台权限&#xff1a;登陆了后台&#xff0…