V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
ooToo
V2EX  ›  程序员

怎样高效遍历联合主键的表?

  •  
  •   ooToo · 2023-02-14 08:28:58 +08:00 · 1606 次点击
    这是一个创建于 673 天前的主题,其中的信息可能已经有所发展或是发生改变。
    create table t
    (
        a int        not null,
        b varchar(128) not null,
        primary key (b, a)
    )
    

    t 有千万行吧, 一般怎么样高效遍历这样的表呢?

    只能select * from t where b = 'xx' and a > 'yy' limit 1000?

    问题是 column b 区分度大的话, 每次取到的数据可能远小于 1000

    上面用 mysql 的方式讨论一般思路, 其实这个 DB 是 SQL server(第一次用 SQL server), 有特殊技巧吗?

    8 条回复    2023-02-14 17:54:57 +08:00
    xuanbg
        1
    xuanbg  
       2023-02-14 08:35:24 +08:00
    这个 sql 应该是走索引的,所以并不存在全表扫描啊
    lovelylain
        2
    lovelylain  
       2023-02-14 08:42:36 +08:00 via Android   ❤️ 1
    select * from t where (b > 'xx' or b = 'xx' and a > 'yy') order by b,a limit 1000
    lovelylain
        3
    lovelylain  
       2023-02-14 08:44:31 +08:00 via Android
    select * from t where b >= 'xx' and (b > 'xx' or a > 'yy') order by b,a limit 1000
    csrocks
        4
    csrocks  
       2023-02-14 09:10:46 +08:00
    那就不 limit 呗, 设置个数量 N, 逐条读取, 读满了就停止, 然后记录本次的 a: a1, 下次 `select * from t where b='xx' and a>'a1' order by a`
    ooToo
        5
    ooToo  
    OP
       2023-02-14 11:25:43 +08:00
    @jobmailcn 很赞 多谢啦.
    不过 3 楼的不对吧,
    我用这个 where (b = 'xx' and a > 'yy') or b > 'xx'
    ooToo
        6
    ooToo  
    OP
       2023-02-14 11:26:22 +08:00
    @xuanbg 对, 走索引. 问题在于怎么遍历
    lovelylain
        7
    lovelylain  
       2023-02-14 12:57:34 +08:00 via Android
    @ooToo 逻辑上是等效的,2 楼是 or 条件更容易理解,3 楼是 and 条件对索引利用可能更好一些
    ooToo
        8
    ooToo  
    OP
       2023-02-14 17:54:57 +08:00
    @jobmailcn 看明白了, 再次感谢
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3089 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 13:41 · PVG 21:41 · LAX 05:41 · JFK 08:41
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.