欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

SQLSERVER是怎麽通过索引和统计信息来找到目标数据的(第一篇)

程序员文章站 2022-06-10 19:19:49
...

SQLSERVER是怎麽通过索引和统计信息来找到目标数据的(第一篇) 在第一篇里大家先搭建好测试环境,了解SQL Server中的执行引擎,了解一下表的信息,在第二篇再跟大家详细地说清楚索引 在第三篇里跟大家说一下统计信息。 因为篇幅比较长,所以暂时分成第一篇、

SQLSERVER是怎麽通过索引和统计信息来找到目标数据的(第一篇)

在第一篇里大家先搭建好测试环境,了解SQL Server中的执行引擎,了解一下表的信息,在第二篇再跟大家详细地说清楚索引

在第三篇里跟大家说一下统计信息。

因为篇幅比较长,所以暂时分成第一篇、第二篇、第三篇,不然大家看得很痛苦

---------------------------------------------------------------开始-----------------------------------------------------

先给出一篇文章的地址,都是博客园里的文章:

http://www.cnblogs.com/CareySon/archive/2012/05/23/CoreConceptOfExcutionEngine.html

《SQL Server中的执行引擎入门》,这篇文章主要讲了:执行引擎、执行计划、查询优化器

对执行引擎 、执行计划的了解或者掌握对SQLSERVER的索引查找数据方法是很有必要的,因为是环环相扣

如果阁下不对执行引擎 、执行计划先进行一下了解,下面的内容阁下会看得一头雾水

再看一下SQLSERVER为每个表记录了哪些信息 因为博客园的图片上传功能出了一些问题

我先给出图片链接

SQLSERVER是怎麽通过索引和统计信息来找到目标数据的(第一篇)

打开SSMS,点击表的+号,可以看到SQLSERVER一般记录了表的列信息、主键、约束、触发器、索引和统计信息

列信息、主键、约束、触发器就不说了,一般SQLSERVER查找目标数据都要使用到索引统计信息

--------------------------------------------搭建测试环境-----------------------------------------------

请确保阁下的计算机里有范例数据库AdventureWorks,并在数据库里建立两张新的规范表格

 1 USE [AdventureWorks]
 2 
 3 DROP TABLE [dbo].SalesOrderHeader_test
 4 GO
 5 DROP TABLE [dbo].SalesOrderDetail_test
 6 GO
 7 
 8 SELECT * INTO dbo.SalesOrderHeader_test
 9 FROM sales.[SalesOrderHeader]
10 GO
11 
12 SELECT * INTO [dbo].SalesOrderDetail_test
13 FROM sales.[SalesOrderDetail]
14 GO
15 
16 CREATE CLUSTERED INDEX SalesOrderHeader_test_CL
17 ON [dbo].SalesOrderHeader_test([SalesOrderID])
18 
19 GO
20 
21 CREATE INDEX SalesOrderDetail_test_NCL
22 ON [dbo].SalesOrderDetail_test([SalesOrderID])
23 GO

dbo.SalesOrderHeader_test:存放的是每一张订单的头信息,包括订单创建日期、客户编号、

合同编号、销售员编号等,每个订单都有一个单独的订单号在订单号这个字段上,有一个聚集索引

dbo.SalesOrderDetail_test:存放的是订单的详细内容。一张订单可以销售多个产品给同一个客户,

所以SalesOrderHeader_test和SalesOrderDetail_test是一对多的关系。每条详细内容包括他所属的订单编号,

他自己在表格里的唯一编号(SalesOrderDetailID)、产品编号、单价、销售数量等,在这里,先只在[SalesOrderID]

上建立一个非聚集索引

按照AdventureWorks里原先的数据,dbo.SalesOrderHeader_test里有3W多条订单信息,

dbo.SalesOrderDetail_test里有12W多条订单详细记录,基本上一条订单有3~5条详细记录,

这是一个正常的分布

下面再在dbo.SalesOrderHeader_test里加入9条订单记录,他们的编号是从75124到75132

这是9张特殊的订单,每张有12W多条详细记录。也就是说:dbo.SalesOrderDetail_test里会有

90%的数据属于这9张订单。请用下面这段代码来得到模拟数据:

 1 USE [AdventureWorks]
 2 GO
 3 DECLARE @i INT
 4 SET @i=1
 5 WHILE @i9