首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >选择顶部扫描整个表格

选择顶部扫描整个表格
EN

Stack Overflow用户
提问于 2010-07-29 21:08:44
回答 4查看 666关注 0票数 2

如果我执行如下命令:

代码语言:javascript
运行
复制
SELECT TOP(10000) ProductId from ProductInfo WHERE ProductId IN
(
    SELECT ProductId from DeletedProduct
)

它会扫描整个表,还是会在找到10000后立即爆发?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-07-29 21:10:52

一旦找到10000,它就会爆发。

您没有使用我的删除解决方案吗?:-)

票数 2
EN

Stack Overflow用户

发布于 2010-07-29 21:13:24

我认为如果您执行内部连接,您的查询会更快,如下所示:

代码语言:javascript
运行
复制
SELECT TOP(10000) P.ProductId
FROM ProductInfo P INNER JOIN DeletedProduct D on P.ProductId=D.ProductId
票数 1
EN

Stack Overflow用户

发布于 2010-07-29 21:26:54

如果您只对ProductInfo中的ProductID (而不是其他列)感兴趣,并且只是使用in来验证该产品是否确实存在,那么这样的操作可能会更快。

在management studio中同时运行您的查询和下面的查询显示,您的查询的成本为99%,而下面的查询的成本为1% (快得多);然而,这可能只是因为我正在使用的数据库。

代码语言:javascript
运行
复制
SELECT TOP(10000) ProductId
FROM DeletedProduct D
WHERE EXISTS (SELECT * FROM ProductInfo P WHERE P.ProductID=D.ProductID )
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3362764

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档