• orcale 使用创建日期排序然后分页每次取排序后的固定条数


    需求:

         一个使用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条数据

  • 相关阅读:
    poj2823单调队列认知
    有关二叉树的三序遍历的题目
    hdu4757 可持续字典树
    ZOJ2532判断边是否是割集中的边
    poj2455 k条路最小化最长边
    乘法逆元模板
    poj1699 KMP+壮压DP
    Innodb存储引擎——非聚集索引
    java集合框架笔记
    jvm垃圾回收
  • 原文地址:https://www.cnblogs.com/gczmn/p/7997992.html
Copyright © 2020-2023  润新知