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

查看 67|回复 3
作者: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), 有特殊技巧吗?

遍历, null, SQL, Server

xuanbg   
这个 sql 应该是走索引的,所以并不存在全表扫描啊
jobmailcn   
select * from t where (b > 'xx' or b = 'xx' and a > 'yy') order by b,a limit 1000
jobmailcn   
select * from t where b >= 'xx' and (b > 'xx' or a > 'yy') order by b,a limit 1000
您需要登录后才可以回帖 登录 | 立即注册

返回顶部