如果我执行如下命令:
SELECT TOP(10000) ProductId from ProductInfo WHERE ProductId IN
(
SELECT ProductId from DeletedProduct
)它会扫描整个表,还是会在找到10000后立即爆发?
发布于 2010-07-29 21:10:52
一旦找到10000,它就会爆发。
您没有使用我的删除解决方案吗?:-)
发布于 2010-07-29 21:13:24
我认为如果您执行内部连接,您的查询会更快,如下所示:
SELECT TOP(10000) P.ProductId
FROM ProductInfo P INNER JOIN DeletedProduct D on P.ProductId=D.ProductId发布于 2010-07-29 21:26:54
如果您只对ProductInfo中的ProductID (而不是其他列)感兴趣,并且只是使用in来验证该产品是否确实存在,那么这样的操作可能会更快。
在management studio中同时运行您的查询和下面的查询显示,您的查询的成本为99%,而下面的查询的成本为1% (快得多);然而,这可能只是因为我正在使用的数据库。
SELECT TOP(10000) ProductId
FROM DeletedProduct D
WHERE EXISTS (SELECT * FROM ProductInfo P WHERE P.ProductID=D.ProductID )https://stackoverflow.com/questions/3362764
复制相似问题