SQLServer数据库的相关性能问题与隐式转换

来源:计算机等级考试    发布时间:2012-08-27    计算机等级考试视频    评论

导读:此文章主要向大家描述的是正确的隐式转换与SQL Server数据库的相关性能问题,面临的问题可以对其通过在HumanResources.Employee表的SQL Server 2005 AdventureWorks数据库中做一个类似的查询来看到。

为了帮助我们更好地理解SQL Server在我们运行这些查询时都做了什么,让我们来查找IO统计数据,

我面临的问题可以通过在HumanResources.Employee表的SQL Server 2005 AdventureWorks数据库中做一个类似的查询来看到。为了帮助我们更好地理解SQL Server在我们运行这些查询时都做了什么,让我们来查找IO统计数据,并且使用SSMS菜单命令Query/Include Actual Execution Plan。

为了使用AdventureWorks数据库并且启用IO统计数据,让我们从下面的查询开始:

use AdventureWorks   go  SET STATISTICS IO ON  go

这是对Employee表的一个查询,它类似于给我带来上述麻烦的查询:

SELECT EmployeeID, NationalIDNumber, LoginID   FROM HumanResources.Employee  WHERE NationalIDNumber = 112457891 go

它看起来似乎不会给我们带来什么麻烦。HumanResources.Employee表有一个以NationalIDNumber开始的索引,因此执行这个查询只是查找112457891的位置然后对这个表的行作查找。但是统计数据和查询计划显示了事情并非如此简单。这是相关的信息:

EmployeeID NationalIDNumber LoginID   4 112457891 adventure-works/rob0  (1 row(s) affected)  Table 'Employee'. Scan count 1, logical reads 6,  physical reads 0, read-ahead reads 0,  lob logical reads 0, lob physical reads 0,  lob read-ahead reads 0.  (1 row(s) affected)

该统计数据显示有一个扫描,而这正是问题所在。Adventureworks.HumanResources.Employee只有291行,因此这可能真的可以很快地运行并且看似不会造成什么问题。我使用的表有数百万行,表扫描正是凶手,因为它对于每次查询都要花几秒的时间。

上一页12下一页

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答