一、全局视野法
假如是按主键取模来分库的
每个库都执行:order by time offset 0 limit X+Y;
服务层对得到的N个库乘以(X+Y)条数据进行内存排序,内存排序后再取偏移量X后的Y条记录;
缺点:页码越大,取出来的数据越多。
二、禁止跳页查询法
(1)用正常的方法(第一种方法)取得第一页数据,并得到第一页记录的time_max;
(2)每次翻页,将
order by time offset X limit Y;
改写成
order by time where time>$time_max limit Y;
以保证每次只返回一页数据,性能为常量。
三、二次查询法
(1)SQL改写,将
order by time offset X limit Y;
改写成
order by time offset X/N limit Y;
N代表分库的数量。
(2)多页返回,找到最小值time_min;
(3)二次查询
order by time between $time_min and $time_i_max;
(4)二次查询的结果,合并,排序,得出结果