浅谈SQL Server 2008中的行压缩

在创建表或索引,或者修改表或索引时可以启用行压缩特性。压缩可以基于行级、页面级和备份级,本文将举例说明如何创建一个具备行压缩功能的表,以及修改一个表,使其具备行压缩功能。

首先创建一个未开启行压缩功能的表,使用下面的SQL语句往表里插入一些数据:

 
 
 
  1. /****** Object: Table [dbo].[NoNCompressed Table]  
  2. Script Date: 05/27/2009 02:24:23 ******/  
  3. IF EXISTS (SELECT * FROM sys.objects  
  4. WHERE object_id = OBJECT_ID(N'[dbo].[NoNCompressed Table]')  
  5. AND type in (N'U'))  
  6. DROP TABLE [dbo].[NoNCompressed Table]  
  7. GO  
  8. CREATE TABLE [NoNCompressed Table]  
  9. (id int, FName varchar(100), LName varchar(100))  
  10. --增加10,000行  
  11. declare @n int  
  12. set @n=0 
  13. while @n<=10000  
  14. begin  
  15. insert into [NoNCompressed Table] values  
  16. (1,'Adam','Smith'),(2,'Maria','carter'),(3,'Walter','zenegger')  
  17. set @n=@n+1  
  18. end  
  19. GO 

然后使用下面的SQL语句查询这个表占用的空间大小:

 
 
 
  1. EXEC sp_spaceused [NONCompressed Table] 

返回结果:

 
 
 
  1. name,rows,reserved,data,index_size,unused  
  2. NoNCompressed Table,30003 ,968 KB,944 KB,8 KB,16 KB 

现在我们创建一个启用了行压缩的表,使用下面的SQL语句插入相同数量的数据:

 
 
 
  1. /****** Object: Table [dbo].[Compressed Table]  
  2. Script Date: 05/27/2009 02:24:57 ******/  
  3. IF EXISTS (SELECT * FROM sys.objects  
  4. WHERE object_id = OBJECT_ID(N'[dbo].[Compressed Table]')  
  5. AND type in (N'U'))  
  6. DROP TABLE [dbo].[Compressed Table]  
  7. GO  
  8. CREATE TABLE [Compressed Table]  
  9. (id int, FName varchar(100), LName varchar(100)) with  
  10. (Data_compression = ROW)  
  11. declare @n int  
  12. set @n=0 
  13. --添加10,000行  
  14. while @n<=10000  
  15. begin  
  16. insert into [Compressed Table] values  
  17. (1,'Adam','Smith'),(2,'Maria','carter'),(3,'Walter','zenegger')  
  18. set @n=@n+1  
  19. end  
  20. GO 

使用下面的SQL语句查询表的空间占用情况:

EXEC sp_spaceused [Compressed Table]

返回结果:

name,rows,reserved,data,index_size,unused

Compressed Table,30003 ,584 KB,576 KB,8 KB,0 KB

结果显示压缩表比非压缩表占用的空间小得多。

有一种情况是表中已经有很多数据,但现在需要进行压缩,该怎么办呢?在这种情况下,可以ALTER TABLE语句增加数据压缩功能,我们创建另一个未启用压缩功能的表来模拟一下,使用下面的SQL语句添加数据到表中:

 
 
 
  1. /****** Object: Table [dbo].[NoNCompressed Table] Script Date: 05/27/2009 02:24:23 ******/  
  2. IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[NoNCompressed Table2]') AND type in (N'U'))  
  3. DROP TABLE [dbo].[NoNCompressed Table2]  
  4. GO  
  5. CREATE TABLE [NoNCompressed Table2]  
  6. (id int, FName varchar(100), LName varchar(100))  
  7. declare @n int  
  8. set @n=0 
  9. while @n<=10000  
  10. begin  
  11. insert into [NoNCompressed Table2] values  
  12. (1,'Adam','Smith'),(2,'Maria','carter'),(3,'Walter','zenegger')  
  13. set @n=@n+1  
  14. end  
  15. GO 

使用下面的SQL语句查询该表占用的空间大小:

 
 
 
  1. EXEC sp_spaceused [NONCompressed Table2] 

返回结果:

 
 
 
  1. name,rows,reserved,data,index_size,unused  
  2. NoNCompressed Table,30003 ,968 KB,944 KB,8 KB,16 KB 

使用下面的ALTER TABLE语句启用表的压缩功能:

 
 
 
  1. ALTER TABLE [NoNCompressed Table2]  
  2. REBUILD WITH (DATA_COMPRESSION = ROW ); 

然后使用下面的SQL语句查询表的空间占用情况:

 
 
 
  1. EXEC sp_spaceused [NONCompressed Table2] 

返回结果:

name,rows,reserved,data,index_size,unused

NoNCompressed Table2,30003 ,592 KB,560 KB,8 KB,24 KB

【编辑推荐】

  1. SQL Server 2008中位置智能应用程序可扩展性
  2. SQL Server 2008中使用空间数据实现位置智能
  3. SQL Server数据库优化经验总结
  4. 浅谈Netbeans 6.5连接SQL Server 2008方法
  5. 使用SQL Server 2008进行优化性能
THE END