为了账号安全,请及时绑定邮箱和手机立即绑定

Select * 真的不走索引吗

标签:
SQL Server

走索引指的是:SQL语句的执行计划用到了1、聚集索引查找  2、索引查找  ,并且查询语句中需要有where子句

根据where子句的过滤条件,去聚集索引或非聚集索引那里查找记录

一张表只有一列的情况:

聚集索引


 1 USE [tempdb]
 2 GO
 3 CREATE TABLE t1 ( id INT )
 4 GO
 5 CREATE CLUSTERED INDEX CIX_T1 ON [dbo].[t1](ID ASC)
 6 GO
 7 
 8 
 9 DECLARE @I INT
10 SET @I = 1
11 WHILE @I < 1000 
12     BEGIN
13         INSERT  INTO [dbo].[t1] ( [id] )
14                 SELECT  @I
15         SET @I = @I + 1
16     END
17 
18 SELECT * FROM [dbo].[t1] WHERE [id]=20

 

非聚集索引

 1 USE [tempdb]
 2 GO
 3 
 4 CREATE TABLE t2 ( id INT )
 5 GO
 6 CREATE NONCLUSTERED INDEX IX_T2 ON [dbo].[t2](ID ASC)
 7 GO
 8 
 9 
10 DECLARE @I INT
11 SET @I = 1
12 WHILE @I < 1000 
13     BEGIN
14         INSERT  INTO [dbo].[t2] ( [id] )
15                 SELECT  @I
16         SET @I = @I + 1
17     END
18 
19 SELECT * FROM [dbo].[t2] WHERE [id]=20


只有一列,肯定会走索引的


一张表有多列的情况

分三种情况:

1、只有聚集索引

2、只有非聚集索引

3、有聚集索引和非聚集索引


只有聚集索引


 1 --只有聚集索引
 2 USE [tempdb]
 3 GO
 4 CREATE TABLE Department  
 5 (
 6   DepartmentID INT IDENTITY(1, 1) NOT NULL PRIMARY KEY,
 7   Name NVARCHAR(200) NOT NULL ,
 8   GroupName NVARCHAR(200) NOT NULL ,
 9   Company NVARCHAR(300) ,
10   ModifiedDate DATETIME NOT NULL DEFAULT ( GETDATE() ) 
11 
12 )
13 
14 
15 DECLARE @i INT
16 SET @i=1
17 WHILE @i < 100000 
18     BEGIN
19         INSERT  INTO Department ( name, [Company], groupname )
20         VALUES  ( '销售部'+CAST(@i AS VARCHAR(200)), '中国你好有限公司XX分公司', '销售组' )
21         SET @i = @i + 1
22     END
23 
24 
25 SELECT * FROM [dbo].[Department] WHERE [DepartmentID]=2


小结:

只有聚集索引的表:如果where后面不包括创建聚集索引的时候的第一个字段,就会使用聚集索引扫描

下面SQL语句会使用聚集索引查找,因为包括了创建聚集索引的时候的第一个字段

1 SELECT * FROM [dbo].[Department] WHERE [Company]='销售部12' AND [DepartmentID]=12

只有非聚集索引


 1 --只有非聚集索引
 2 USE [tempdb]
 3 GO
 4 
 5 CREATE TABLE Department  
 6 (
 7   DepartmentID INT IDENTITY(1, 1) NOT NULL ,
 8   Name NVARCHAR(200) NOT NULL ,
 9   GroupName NVARCHAR(200) NOT NULL ,
10   Company NVARCHAR(300) ,
11   ModifiedDate DATETIME NOT NULL DEFAULT ( GETDATE() ) 
12 
13 )
14 
15 CREATE NONCLUSTERED INDEX IX_Department ON Department(DepartmentID ASC)
16 
17 
18 DECLARE @i INT
19 SET @i=1
20 WHILE @i < 100000 
21     BEGIN
22         INSERT  INTO Department ( name, [Company], groupname )
23         VALUES  ( '销售部'+CAST(@i AS VARCHAR(200)), '中国你好有限公司XX分公司', '销售组' )
24         SET @i = @i + 1
25     END
26 
27 
28 SELECT * FROM [dbo].[Department] WHERE [Company]='销售部12' AND [DepartmentID]=12


 

小结:

只有非聚集索引的表:如果where后面不包括创建非聚集索引的时候的第一个字段,就会使用表扫描或者索引扫描

下面SQL语句会使用非聚集索引查找,因为包括了创建非聚集索引的时候的第一个字段

1 SELECT * FROM [dbo].[Department] WHERE [Company]='销售部12' AND [DepartmentID]=12

 


有聚集索引也有非聚集索引


 1 --有聚集索引和非聚集索引
 2 USE [tempdb]
 3 GO
 4 
 5 CREATE TABLE Department  
 6 (
 7   DepartmentID INT IDENTITY(1, 1) NOT NULL PRIMARY KEY,
 8   Name NVARCHAR(200) NOT NULL ,
 9   GroupName NVARCHAR(200) NOT NULL ,
10   Company NVARCHAR(300) ,
11   ModifiedDate DATETIME NOT NULL DEFAULT ( GETDATE() ) 
12 
13 )
14 
15 CREATE NONCLUSTERED INDEX IX_Department ON Department(Company ASC)
16 
17 
18 DECLARE @i INT
19 SET @i=1
20 WHILE @i < 100000 
21     BEGIN
22         INSERT  INTO Department ( name, [Company], groupname )
23         VALUES  ( '销售部'+CAST(@i AS VARCHAR(200)), '中国你好有限公司XX分公司', '销售组' )
24         SET @i = @i + 1
25     END


小结:

有聚集索引和非聚集索引的表:如果where后面包括创建聚集索引的时候的第一个字段,就会使用聚集索引查找

如果where后面包括创建非聚集索引的时候的第一个字段但不包括创建聚集索引的时候的第一个字段,就会使用索引查找

如果where后面不包括创建非聚集索引的时候的第一个字段和不包括创建聚集索引的时候的第一个字段,就会使用聚集索引扫描

1 SELECT * FROM [dbo].[Department] WHERE [GroupName]='销售组'


总结

其实走不走索引,关键取决于where后面包括还是不包括

创建聚集索引的时候的第一个字段

创建非聚集索引的时候的第一个字段

跟select *没有关系的,select * 最大的影响就是额外的IO开销

像“键查找” ,“RID查找”这些运算符就是额外的开销

键查找:到聚集索引里找其他字段的值

RID查找:到堆表里找其他字段的值

 

 造成额外的书签查找或是由查找变为扫描

由查找变为扫描,查找还是扫描决定于我刚才所说的话:

其实走不走索引,关键取决于where后面包括还是不包括

创建聚集索引的时候的第一个字段

创建非聚集索引的时候的第一个字段

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消