SELECT * 的真相: 索引覆盖(index coverage)

SELECT *的效率很糟糕吗?当然,所有人都知道这一点,但是为什么呢?

是因为返回了太多的数据?

这是一个普遍的回答,但我不这样认为。如果你的数据库设计规范合理,那么带宽占用实际上非常的小。

让我们看看下面的例子。下面的查询将会从AdventureWorks.dbo.TransactionHistoryArchive(总共大约有近9万行数据)中选择出326行数据。第一个使用了SELECT * 查询,后一个查询则有明确的字段。

SELECT   *   FROM  Production.TransactionHistoryArchive 
WHERE  ReferenceOrderID  <   100

SELECT  ReferenceOrderLineID  FROM  Production.TransactionHistoryArchive 
WHERE  ReferenceOrderID  <   100

在这种情况下,两者在网络带宽的区别只有15K(180K-165K),大约10%的带宽差异。的确值得去优化,但不会有很大的效果。

SELECT * 将造成表/索引扫描

SELECT * 的最大问题是将影响查询计划。SQL Server主要使用索引去查询你需要的数据,当索引包括所有的你请求查询的字段,SQL Server将不需要去在表中查询。这个概念称做索引覆盖。在上面的例子中,第一个查询结果是在聚集索引扫描中,反过来,第二个例子使用了更多更有效率的索引扫描。在这个案例中,索引扫描比聚集索引扫描快100倍

o_SelectStarQueryPlan.gif

除非你已经将为每个字段建立了索引(显然不是个好主意),SELECT *是不能够利用到索引覆盖,你只能去做扫描操作(非常的没有效率)。

如果你只是查询你所需要的字段,那你更可能的覆盖到你的索引。我想这就是不推荐使用SELECT *的主要的原因。

稳定性方面

在维护一个应用程序时,SELECT *也会带来一些意想不大的问题。它会引起你的代码发生一些不确定性。如果你增加了一个行(译注:我觉得这里应该是字段)到一个表中,那么SELECT * 返回的结果到你的应用程序中将会在结构上发生变化。良好的应用程序应该是使用字段名称的,而不应该受此影响。当外界发生变化时,良好的应用程序设计也应该最小化的更改。

英文原稿: http://weblogs.asp.net/jgalloway/archive/2007/07/18/the-real-reason-select-queries-are-bad-index-coverage.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当我们执行一条 SQL 查询语句使用 `SELECT *` 时,它会返回被查询表中所有的列。然而,如果在这个查询中索引失效了,意味着数据无法高效地被检索,可能会导致查询性能下降。 索引失效可能有多种原因。一种常见的原因是在查询中使用了不符合索引的操作符或函数。例如,使用`LIKE`操作符进行模糊匹配时,如果使用了通配符`%`在搜索模式的开始处,索引就会失效。此外,还有一些函数(如`LOWER()`或`UPPER()`)可以使索引失效。所以,在编写查询时要注意使用正确的操作符和函数,以确保索引生效。 另一个可能导致索引失效的原因是统计信息不准确。数据库通过统计信息来进行执行计划的优化和索引选择。如果统计信息过期或不准确,数据库可能会错误地选择不合适的索引,从而导致索引失效。为了解决这个问题,我们可以定期更新统计信息或手动收集统计信息,以确保索引使用正确。 此外,索引失效还可能是因为表中的数据分布不均匀。如果某个索引列上的数据分布不均匀,那么使用该列进行查询的时候,索引就可能失效。在这种情况下,我们可以考虑重新设计索引,或者使用其他的查询优化方法来改进性能。 总而言之,当 `SELECT *` 查询的索引失效时,我们需要检查查询中使用的操作符和函数是否符合索引,同时确保统计信息准确和数据分布均匀。通过这些方法,我们可以提高查询的性能并避免索引失效的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值