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

2023-02-14 08:28:58 +08:00
 ooToo
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), 有特殊技巧吗?

1407 次点击
所在节点    程序员
8 条回复
xuanbg
2023-02-14 08:35:24 +08:00
这个 sql 应该是走索引的,所以并不存在全表扫描啊
lovelylain
2023-02-14 08:42:36 +08:00
select * from t where (b > 'xx' or b = 'xx' and a > 'yy') order by b,a limit 1000
lovelylain
2023-02-14 08:44:31 +08:00
select * from t where b >= 'xx' and (b > 'xx' or a > 'yy') order by b,a limit 1000
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
2023-02-14 11:25:43 +08:00
@jobmailcn 很赞 多谢啦.
不过 3 楼的不对吧,
我用这个 where (b = 'xx' and a > 'yy') or b > 'xx'
ooToo
2023-02-14 11:26:22 +08:00
@xuanbg 对, 走索引. 问题在于怎么遍历
lovelylain
2023-02-14 12:57:34 +08:00
@ooToo 逻辑上是等效的,2 楼是 or 条件更容易理解,3 楼是 and 条件对索引利用可能更好一些
ooToo
2023-02-14 17:54:57 +08:00
@jobmailcn 看明白了, 再次感谢

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/915882

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX