需求:
一个使用mybatis分页插件的分页列表, 现在要求新增一条数据或者修改一条数据后,显示在最前端
思路:
使用sql , 先将查询出来的数据排序, 然后使用rownum > page*size 和rownum <= (page+1)*size 条件取固定条数的数据
问题 :
执行sql时遇到一个问题, 因为使用order by tn.create_time desc 进行降序排列,是在where条件查询后, 所以rownum序号已经生成, 在排序rownum的值不会变, 改变的是数据顺序 ,
当使用rownum > page*size 和rownum <= (page+1)*size取值时其实取的就是没排序前的固定条数, 也就是说, order by虽然排序了, 可以取值没有取排完序后的数据
解决方法:
方法一:
SELECT *
FROM (
SELECT tn.ID,
ROW_NUMBER() OVER(PARTITION BY tn.valid ORDER BY NVL(tn.modify_time,tn.create_time) desc) RN
FROM table_name tn
JOIN table_name2 tn2 ON tn.ID = tn2.ID
WHERE tn.condition = '条件'
)
WHERE RN >(page*size) AND RN <= (page + 1)*size;
因为观察数据特点,发现存在一个标志可用不可用状态的字段, 所以使用 ROW_NUMBER() OVER (PARTITION BY COL1 ORDER BY COL2) 表示根据COL1分组,在分组内部根据 COL2排序,
根据可用状态分组,所有可用的就会进行编号,然后根据创建时间或者修改时间进行组内排序 ,又因为新增的数据没有修改时间,而新增后创建时间不变,只有修改时间改变,所以使用 NVL(tn.modify_time,tn.create_time) 判断,
如果修改时间为空(新增操作)就使用创建时间排序, 如果修改时间不为空(修改操作)那么就使用创建时间排序, 然后使用 WHERE RN >(page*size) AND RN <= (page + 1)*size 传入page(第几页)和size(每页长度)获取数据
方法二 :
select * from
(
select row_.*, rownum rownum_ from
(
select od.*,rownum from
(
select *
from table_name tn
join table_name2 tn2 ON tn.ID = tn2.ID
WHERE tn.condition = '条件' order by NVL(tn.modify_time,tn.create_time) DESC
) od
) row_ where rownum <= (page + 1)*size
)where rownum_ > (page*size);
这是另一个思路, 首先将所有符合条件的数据根据创建时间进行排序,形成一张按创建时间排序的临时表,然后在给这张表添加上rownum序号,并取出 rownum <= (page + 1)*size 条数据,
形成排序后的前 (page + 1)*size 条临时表,最后取出需要的(page*size)到(page + 1)*size条数据