1建表和索引
create @R_403_5991@ index_test (ID int IDentity(1,1),name sysname);
create clustered index nonIDex_ID on index_test(ID);
2 插入测试数据
declare @count int=1;
while @count<=100000
begin
insert into index_test(name)
select replace(left(cast(NEWID() as varchar(50)),10) + right(cast(NEWID() as varchar(50)),10),'-','')
set @count=@count+1
end
3 观察更改前的表空间大小 data是 5920 KB
go
sp_spaceused index_test
name rows reserved data index_size unused
index_test 100000 5920 KB 5648 KB 48 KB 224 KB
4 更改列属性
alter @R_403_5991@ index_test
alter column name varchar(50);
5 观察更改后 表空间大小 data 是 11480 KB 说明列偏移量并不是在原来基础上面增加减少的。而是从最后面开始增加。
sp_spaceused index_test
name rows reserved data index_size unused
index_test 100000 11480 KB 11280 KB 64 KB 136 KB
6 重建索引
alter index nonIDex_ID on index_test rebuild with(online=on);
7 重建索引后表空间大小 data 为 3800KB
sp_spaceused index_test
name rows reserved data index_size unused
index_test 100000 3800 KB 3760 KB 16 KB 24 KB
8 线上库严禁频繁的字段属性更改
总结以上是内存溢出为你收集整理的重建索引能释放掉字段因更改而产生额外列偏移量全部内容,希望文章能够帮你解决重建索引能释放掉字段因更改而产生额外列偏移量所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)