怎么取消自增列上的聚集索引

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么取消自增列上的聚集索引相关的知识,希望对你有一定的参考价值。

数据库中有一个表,表中包含了一个自增的ID列作为主键。数据库自动在这个ID上建立了聚集索引。如果这个ID对于查询并没有用处,我想在别的列上建聚集索引,应该怎么取消这个ID上的聚集索引呢?
俺知道咧。谢谢各位了!百度提问现在不能关闭问题,真是烦恼。

参考技术A truncate table notice ,然后重新插入数据 参考技术B sqlserver自动对主键建立聚集索引,所以数据一般来说,是按照主键的顺序存储的。

所以,如果要取消聚集索引,则必须删除此主键。追问

删除主键后,该怎么设置还可以实现这个ID的唯一且自增呢?

参考技术C 取消主键

查看表扫描次数,并对比索引对表查询的作用

1、什么是表扫描

当执行SQL 语句时,可通过“”评估执行计划”,查看语句的执行计划。尤其是语句设计查询,会出现“表扫描”部分;

表扫描是严重影响查询时间的因素!

2、验证

(1)新建数据表BasicMsg20161204,主键为自增列,但是将聚集索引建立在(RecvTime,AA,MsgTypecode)上;

(2)新建数据表BasicMsg20161104,主键为自增列,且该列为聚集索引;在RecvTime上有非聚集索引;

(3)新建数据表BasicMsg20161004,主键为自增列,且该列为聚集索引;没有任何其他索引。

        表中共有347758行数据, 查看三表的IO读写情况:

--//----------------------------------------------

--1、查看该表的IO读写情况

DBCC DROPCLEANBUFFERS --清空所有的缓存区内容
SET STATISTICS IO ON 
SELECT * FROM BasicMsg20161204 --WHERE IDFlag=347758
SET STATISTICS IO OFF

--2、结果:

--BasicMsg20161204
--(347758 row(s) affected)
--Table ‘BasicMsg20161204‘. Scan count 1, logical reads 6594, physical reads 2, read-ahead reads 6596, lob logical reads 0, lob physical reads 0, lob read-ahead reads 0.
--扫描计数1次,逻辑读取6594次!物理读取2次,预读6594次,lob逻辑读取0次...
--
BasicMsg20161104
--(347758 row(s) affected)
--Table ‘BasicMsg20161104‘. Scan count 1, logical reads 6575, physical reads 3, read-ahead reads 6596, 
--扫描计数1次,逻辑读取6575次!物理读取3次,预读6575次,lob逻辑读取0次...

--3、分析

  发现,当未用WHERE 语句对索引列进行条件筛选时,前两表的逻辑读取都比较大,索引没有明显作用;未加任何索引的1004表的预读次数反而少;

(1)当在查询语句后加 WHERE RecvTime<=17999995限制条件,扫描次数一样

(2)当在查询语句后加 WHERE RecvTime=17999995限制条件,BasicMsg20161204表的结果为:Scan count 1, logical reads 3, physical reads 3;建立非聚集索引的BasicMsg20161104表为:Scan count 1, logical reads 3, physical reads 3;

  未在RecvTime上加索引,1004表的Table ‘BasicMsg20161004‘. Scan count 9, logical reads 7215, physical reads 2, read-ahead reads 4352,与其他2表的3次和6次,有天壤之别!!

这说明,索引建立在需要具体判定条件的列上才有效。

 --4、DBCC命令协助理解

dbcc ind 命令查看下数据表记录在哪个数据页中

DBCC IND(DF17DataPro,BasicMsg20161104 ,-1) -- (数据库名,表名,参数值)

然后导出该数据页

dbcc traceon(3604)
dbcc page(Ctrip,1,148,1)

以上是关于怎么取消自增列上的聚集索引的主要内容,如果未能解决你的问题,请参考以下文章

我应该摆脱 Guid 列上的聚集索引吗

索引视图的两列上的唯一聚集索引

堆上的非聚集索引与聚集索引的性能 [关闭]

非聚集索引 - 几乎相同需求的一个或两个索引(两个表之间的连接)?

查看表扫描次数,并对比索引对表查询的作用

为什么要建议用自增列做主键