跨库分页
2021-04-23 19:32:53 8 举报
AI智能生成
跨库分页解决方案
作者其他创作
大纲/内容
全局视野法
SQL改写
order by time offset X limit Y;
改写成
order by time offset 0 limit X+Y;
服务层对得到的N*(X+Y)条数据进行内存排序,内存排序后再取偏移量X后的Y条记录
特点
这种方法随着翻页的进行,性能越来越低。
禁止跳页查询法
用正常的方法取得第一页数据,并得到第一页记录的time_max;
order by time offset X limit Y;
改写成
order by time where time>$time_max limit Y;
特点
以保证每次只返回一页数据,性能为常量。
允许模糊数据法
SQL查询改写
order by time offset X limit Y;
改写成
order by time offset X/N limit Y/N;
特点
性能很高,但拼接的结果集不精准。
二次查询法
SQL改写
order by time offset X limit Y;
改写成
order by time offset X/N limit Y;
多页返回,找到最小值time_min;
between二次查询
order by time between $time_min and $time_i_max;
设置虚拟time_min,找到time_min在各个分库的offset,从而得到time_min在全局的offset;
得到了time_min在全局的offset,自然得到了全局的offset X limit Y;
特点
可以精确的返回业务所需数据,每次返回的数据量都非常小,不会随着翻页增加数据的返回量。
0 条评论
下一页