首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用Exists 1或Exists *的子查询

使用Exists 1或Exists *的子查询
EN

Stack Overflow用户
提问于 2009-10-20 21:30:47
回答 4查看 27.7K关注 0票数 92

我过去常常这样写我的EXISTS检查:

IF EXISTS (SELECT * FROM TABLE WHERE Columns=@Filters)
BEGIN
   UPDATE TABLE SET ColumnsX=ValuesX WHERE Where Columns=@Filters
END

以前的一位数据库管理员告诉我,当我执行EXISTS子句时,使用SELECT 1而不是SELECT *

IF EXISTS (SELECT 1 FROM TABLE WHERE Columns=@Filters)
BEGIN
   UPDATE TABLE SET ColumnsX=ValuesX WHERE Columns=@Filters
END

这真的有区别吗?

EN

回答 4

Stack Overflow用户

发布于 2009-10-20 21:32:56

了解这一点的最佳方法是对两个版本进行性能测试,并检查两个版本的执行计划。选择一个有很多列的表。

票数 8
EN

Stack Overflow用户

发布于 2009-10-21 05:37:56

这在SQL Server中没有区别,在SQL Server中也从未出现过问题。优化器知道它们是相同的。如果您查看执行计划,您会发现它们是相同的。

票数 5
EN

Stack Overflow用户

发布于 2009-10-21 05:36:10

就我个人而言,我发现很难相信它们不会针对相同的查询计划进行优化。但是,在您的特定情况下了解它的唯一方法是测试它。如果你有,请反馈给我!

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1597442

复制
相关文章

相似问题

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