sql 分页查询问题,时间范围大的,反而快,这是为什么呢?

谁可以解释一下为什么~--快selecttop16*fromVXFDetailwherenotIDnotin(selecttop(1*16)IDfromVXFDetail... 谁可以解释一下为什么~
--快
select top 16 * from VXFDetail where not ID not in ( select top (1*16) ID from VXFDetail where 1=1
and Date_Time between '2015-01-05 00:00:01' and '2015-01-13 00:00:59' order by Date_Time desc ,ID desc )
and Date_Time between '2015-01-05 00:00:01' and '2015-01-13 00:00:59' order by Date_Time desc
展开
 我来答
gongjiaxiang50
推荐于2020-12-14 · TA获得超过3171个赞
知道大有可为答主
回答量:2432
采纳率:50%
帮助的人:1106万
展开全部
时间范围是子查询的,并且是用not in,范围越大,比较的记录反而越少。
追问
那该怎么办喔?你有没有好点的查询语句,写了几年代码,居然卡在这个问题-_-#
追答
想办法改成用in代替,就回快很多。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2015-01-12
展开全部
比较一下两句的explain plan有什么差别
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式