• <sup id="my82s"><source id="my82s"></source></sup>
  • <legend id="my82s"><div id="my82s"></div></legend>
    <li id="my82s"><tt id="my82s"></tt></li>
    <bdo id="my82s"><rt id="my82s"></rt></bdo>
  • 查看: 446|回复: 15

    [转载] 109-特定场景深度分页SQL优化技巧

    [复制链接]
    论坛徽章:
    407
    紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
    跳转到指定楼层
    1#
    发表于 2023-9-3 16:59 来自手机 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
    https://mp.weixin.qq.com/s/wzFtEEIc3qff9RlMxGgJNA
    论坛徽章:
    407
    紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
    2#
     楼主| 发表于 2023-9-3 17:27 来自手机 | 只看该作者
    在duckdb中造了一些数据
    create or replace table t10m
    as
    with t1 as (select (random()*50)::int16 as owner from range(10000))
    select
    row_number()over()::int as id,a.*
    from t1 a,range(1000) b
    ;


    select owner,count(*) from t10m group by  owner order by 2;

    select id,owner
    from t10m
    where owner=10
    order by id desc
    offset 100 rows fetch next 10 rows only;

    select count(*) from t10m where owner >=10;



    select id,owner
    from t10m
    where owner>=10
    order by id desc
    offset 6000000 rows fetch next 10 rows only;

    使用道具 举报

    回复
    论坛徽章:
    407
    紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
    3#
     楼主| 发表于 2023-9-3 17:54 来自手机 | 只看该作者
    看了原文思路就是把每个owner的数据按id预先算出序号和页号

    使用道具 举报

    回复
    论坛徽章:
    407
    紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
    4#
     楼主| 发表于 2023-9-3 17:56 来自手机 | 只看该作者
    对于包含多个owner的条件查询就不好用了

    使用道具 举报

    回复
    论坛徽章:
    1
    20周年集字徽章-周
日期:2023-08-03 16:37:45
    5#
    发表于 2023-9-3 18:58 | 只看该作者
    〇〇 发表于 2023-9-3 17:56
    对于包含多个owner的条件查询就不好用了

    这种东西不可能是通用的 , 你的这个场景可以拆分成union all。 文章的场景用来优化本论坛可行否?

    使用道具 举报

    回复
    论坛徽章:
    407
    紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
    6#
     楼主| 发表于 2023-9-3 19:08 来自手机 | 只看该作者
    那要在mysql 中测试,忘了5.7支持分析函数没

    使用道具 举报

    回复
    论坛徽章:
    407
    紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
    7#
     楼主| 发表于 2023-9-3 19:12 来自手机 | 只看该作者
    还有一种场景是任意条件查询,比如末尾是A的owner,union  也不行

    使用道具 举报

    回复
    论坛徽章:
    407
    紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
    8#
     楼主| 发表于 2023-9-3 19:21 来自手机 | 只看该作者
    还有经常要对查询结果集任意条件排序再翻页

    使用道具 举报

    回复
    论坛徽章:
    519
    奥运会纪念徽章:垒球
日期:2008-09-15 01:28:12生肖徽章2007版:鸡
日期:2008-11-17 23:40:58生肖徽章2007版:马
日期:2008-11-18 05:09:48数据库板块每日发贴之星
日期:2008-11-29 01:01:02数据库板块每日发贴之星
日期:2008-12-05 01:01:03生肖徽章2007版:虎
日期:2008-12-10 07:47:462009新春纪念徽章
日期:2009-01-04 14:52:28数据库板块每日发贴之星
日期:2009-02-08 01:01:03生肖徽章2007版:蛇
日期:2009-03-09 22:18:532009日食纪念
日期:2009-07-22 09:30:00
    9#
    发表于 2023-9-3 23:32 | 只看该作者
    我和老刘在微信讨论了一点技术上的细节,这里想讨论一下这种需求到底是否存在?
    如果有个用户说,我想看第六百万页的数据,其实他的意思是,我想看一下靠后一点的,随便第几页都行。
    所以,实际上只需要这几个导航按钮:首页,末页,下一页,上一页。中间再放十来个页码让用户挑选。不允许跳跃到指定页码。

    使用道具 举报

    回复
    论坛徽章:
    519
    奥运会纪念徽章:垒球
日期:2008-09-15 01:28:12生肖徽章2007版:鸡
日期:2008-11-17 23:40:58生肖徽章2007版:马
日期:2008-11-18 05:09:48数据库板块每日发贴之星
日期:2008-11-29 01:01:02数据库板块每日发贴之星
日期:2008-12-05 01:01:03生肖徽章2007版:虎
日期:2008-12-10 07:47:462009新春纪念徽章
日期:2009-01-04 14:52:28数据库板块每日发贴之星
日期:2009-02-08 01:01:03生肖徽章2007版:蛇
日期:2009-03-09 22:18:532009日食纪念
日期:2009-07-22 09:30:00
    10#
    发表于 2023-9-3 23:36 | 只看该作者
    如图

    Screenshot_20230903-112125_WeChat.jpg (280.78 KB, 下载次数: 2)

    Screenshot_20230903-112125_WeChat.jpg

    使用道具 举报

    回复

    您需要登录后才可以回帖 登录 | 注册

    本版积分规则 发表回复

    TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
      ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
      ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
    CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
    京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
      
    快速回复 返回顶部 返回列表
    亚洲三级理论
  • <sup id="my82s"><source id="my82s"></source></sup>
  • <legend id="my82s"><div id="my82s"></div></legend>
    <li id="my82s"><tt id="my82s"></tt></li>
    <bdo id="my82s"><rt id="my82s"></rt></bdo>