关于“TOP”的效率问题求助

golden24kcn 2012-10-11 03:39:48
表A有两千万条数据,有SequenceCode列,类型为Int,值是顺序数字。

code, sequncecode

aabcb1233, 1
xxxxb1233, 2
zzfdsb123, 3
.......
pupjfs233, 20000000


因为听说SQL SERVER对于TOP有特别的优化,所以请问如下两个语句,哪个效率更高

select top 10 * from 表A where sequncecode >= 10080

select top 10 * from 表A where sequncecode between 10080 and 10099
...全文
130 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
golden24kcn 2012-10-11
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 的回复:]

SQL code

--单表数据800W,生产库,木分区,测试如下


set statistics io on
dbcc dropcleanbuffers
select top 10 * from TableName where COL>1000000
dbcc dropcleanbuffers
select top 10 * from TableName where COL betwee……
[/Quote]

受教了!!!多谢!!
专注or全面 2012-10-11
  • 打赏
  • 举报
回复

--单表数据800W,生产库,木分区,测试如下


set statistics io on
dbcc dropcleanbuffers
select top 10 * from TableName where COL>1000000
dbcc dropcleanbuffers
select top 10 * from TableName where COL between 1000000 and 1000010


--DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

--(10 行受影响)
--表 '*'。扫描计数 1,逻辑读取 3 次,物理读取 3 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
--DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

--(10 行受影响)
--表 '*'。扫描计数 1,逻辑读取 3 次,物理读取 3 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。


mengzulin 2012-10-11
  • 打赏
  • 举报
回复
最好是用第一条,sequncecode 有索引情况下根本不需要考虑效率问题。如果你用第二条有可能只取到小于10条记录。
golden24kcn 2012-10-11
  • 打赏
  • 举报
回复
谢谢,马上结贴
發糞塗牆 2012-10-11
  • 打赏
  • 举报
回复
因为有索引的话,你的and其实就定位了结尾部分,但是>=可能会一直扫到结尾。但是如果业务需要,还是可以选择>=,具体要看执行计划,那个才是最终结果
golden24kcn 2012-10-11
  • 打赏
  • 举报
回复
我想读取从10080值开始的10行记录。

用sequncecode >= 10080是最符合我的要求,然而但心效率问题,所以用了between。
但是因为sequncecode有可能不是连续的,也在用between 10080到10099,从20行里取前10行。

SequenceCode列已经建立了聚集索引

您的意思,我这种情况,还是用了between比较快吧?
發糞塗牆 2012-10-11
  • 打赏
  • 举报
回复
select top 10 * from 表A where sequncecode >= 10080

select top 10 * from 表A where sequncecode between 10080 and 10099
你这两个都不同的语句,如果你的数据只到10099,而且有索引,那么下面那个快
极品老土豆 2012-10-11
  • 打赏
  • 举报
回复


declare @StartTime datetime
set @StartTime = getdate()

/*语句*/
select datediff(ms,@StartTime,getdate())

vf6.0,要考二级没系统的下哈 Microsoft Visual FoxPro 6.0 for Windows 的常见问题 这些是有关 Microsoft Visual FoxPro 最常见的问题。在您求助 Microsoft 产品支持服务之前,请先查阅这张列表。 若想打印这些附注,请从“文件”菜单中选择“打印”命令。此文档分为以下四部分: --------------------------------------------------------------------- 部分 1. 技术支持与市场 部分 2. Visual FoxPro 6.0 新增功能 部分 3. 从其他版本的 FoxPro 和 Visual FoxPro 中移植 部分 4. Visual FoxPro 常见问题 --------------------------------------------------------------------- 部分 1. 技术支持与市场 问题 1-1: 从何处可以获得产品的更新版本? 答案: 在 Visual FoxPro 的 Web 站点上即可获得产品的更新信息,其中包括有关 Service Pack 和更新的示例、向导及其他代码的信息,该站点的网址为: www.microsoft.com/vfoxpro 请定期查看该网站,以便下载产品的最新版本。 问题 1-2: 从何处可以得到有关 Visual FoxPro 的详细资料? 答案: 通过 Microsoft Visual FoxPro Web 站点是随时获得各种最新产品发布信息的最佳途径。在此站点上不仅有新的产品公告,而且还提供了产品的更新信息、技术文章、白皮书、专业开发人员设计的优秀示例、会议公告、以及与其他许多 FoxPro web 站点的各种链接。 问题 1-3: 如何获得技术支持,以及如何报告软件错误? 答案: Microsoft Visual FoxPro Web 站点已经链接到了多种联机支持选项,其中包括覆盖面广阔的有关所有产品 Microsoft Knowledge Base(Microsoft 知识库)。您还可以阅读一份有关常见问题的清单。除联机支持之外,还可以直接通过电话获得技术支持。“帮助”菜单中的选项可列出技术支持的电话号码。这些电话号码也可用于报告产品中的错误。 问题 1-4. 什么是 Knowledge Base?如何使用它? 答案: Knowledge Base 是内容广泛的论文集,覆盖了如何使用产品的各种特性、已知的软件错误及其解决方案或回避的方法、以及其他有助于使用各种 Microsoft 产品的有用信息。通过以下站点可访问整个 Knowledge Base: support.microsoft.com 问题 1-5: 是否会有 Visual FoxPro 6.0a? 答案: Microsoft 公司一向承诺为用户提供高质量的产品。如果确实需要,我们将提供 Visual FoxPro 6.0 的错误修订版。但是,修订版不会使用 6.0a 版的形式。Visual FoxPro 6.0 中任何错误的修正都将包含在 Visual Studio Service Pack 中。同时还会在 Visual FoxPro 的 www.microsoft.com/vfoxpro 或 Visual Studio 的www.microsoft.com/vstudio 的 Web 站点上发布修订公告。 问题 1-6: Microsoft 公司为应用程序的开发提供了一些优秀的解决方案。怎样才能知道应该向客户推荐和使用哪种产品? 答案: 在选择适用某项任务的产品时,需要考虑多方面的因素。Microsoft Visual FoxPro web 站点上有一份优秀的策略背景论文,它比较了 Visual FoxPro、Visual Basic、SQL Server 和 Access 等 Microsoft 产品之间的不同。 问题 1-7: 哪里可以找到 Visual FoxPro 的使用示例? 答案: Visual FoxPro 6.0 产品中带有丰富的示例,其中有一些是针对 6.0 版特有功能的新示例。与 Visual FoxPro 以前的版本不同,这些示例将与所有 Visual Studio 示例安装在一起。您必须运行 MSDN Library 的“自定义”安装来安装这些示例。在 Visual FoxPro 中可使用新的 HOME(2) 函数方便地找到已安装示例的位置。 除了产品中所自带的示例外,Microsoft Visual FoxPro web 站点还将经常提供新的示例。

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧