ÔÚ´´½¨±í»òË÷Òý£¬»òÕßÐ޸ıí»òË÷Òýʱ¿ÉÒÔÆôÓÃÐÐѹËõÌØÐÔ¡£Ñ¹Ëõ¿ÉÒÔ»ùÓÚÐм¶¡¢Ò³Ãæ¼¶ºÍ±¸·Ý¼¶£¬±¾ÎĽ«¾ÙÀý˵Ã÷ÈçºÎ´´½¨Ò»¸ö¾ß±¸ÐÐѹËõ¹¦ÄÜµÄ±í£¬ÒÔ¼°ÐÞ¸ÄÒ»¸ö±í£¬Ê¹Æä¾ß±¸ÐÐѹËõ¹¦ÄÜ¡£
Ê×ÏÈ´´½¨Ò»¸ö먦ÆôÐÐѹËõ¹¦ÄÜµÄ±í£¬Ê¹ÓÃÏÂÃæµÄSQLÓï¾äÍù±íÀï²åÈëһЩÊý¾Ý£º
/****** Object: Table [dbo].[NoNCompressed Table] Script Date: 05/27/2009 02:24:23 ******/ IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[NoNCompressed Table]') AND type in (N'U')) DROP TABLE [dbo].[NoNCompressed Table] GO CREATE TABLE [NoNCompressed Table] (id int, FName varchar(100), LName varchar(100)) --Ôö¼Ó10,000ÐÐ declare @n int set @n=0 while @n<=10000 begin insert into [NoNCompressed Table] values (1,'Adam','Smith'),(2,'Maria','carter'),(3,'Walter','zenegger') set @n=@n+1 end GO È»ºóʹÓÃÏÂÃæµÄSQLÓï¾ä²éѯÕâ¸ö±íÕ¼ÓõĿռä´óС£º
EXEC sp_spaceused [NONCompressed Table] ·µ»Ø½á¹û£º
name,rows,reserved,data,index_size,unused NoNCompressed Table,30003 ,968 KB,944 KB,8 KB,16 KB ÏÖÔÚÎÒÃÇ´´½¨Ò»¸öÆôÓÃÁËÐÐѹËõµÄ±í£¬Ê¹ÓÃÏÂÃæµÄSQLÓï¾ä²åÈëÏàͬÊýÁ¿µÄÊý¾Ý£º
/****** Object: Table [dbo].[Compressed Table] Script Date: 05/27/2009 02:24:57 ******/ IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[Compressed Table]') AND type in (N'U')) DROP TABLE [dbo].[Compressed Table] GO CREATE TABLE [Compressed Table] (id int, FName varchar(100), LName varchar(100)) with (Data_compression = ROW) declare @n int set @n=0 --Ìí¼Ó10,000ÐÐ while @n<=10000 begin insert into [Compressed Table] values (1,'Adam','Smith'),(2,'Maria','carter'),(3,'Walter','zenegger') set @n=@n+1 end 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
½á¹ûÏÔʾѹËõ±í±È·ÇѹËõ±íÕ¼ÓõĿռäСµÃ¶à¡£
ÓÐÒ»ÖÖÇé¿öÊDZíÖÐÒѾÓкܶàÊý¾Ý£¬µ«ÏÖÔÚÐèÒª½øÐÐѹËõ£¬¸ÃÔõô°ìÄØ?ÔÚÕâÖÖÇé¿öÏ£¬¿ÉÒÔALTER TABLEÓï¾äÔö¼ÓÊý¾ÝѹËõ¹¦ÄÜ£¬ÎÒÃÇ´´½¨ÁíÒ»¸öδÆôÓÃѹËõ¹¦ÄܵıíÀ´Ä£Äâһϣ¬Ê¹ÓÃÏÂÃæµÄSQLÓï¾äÌí¼ÓÊý¾Ýµ½±íÖУº
/****** Object: Table [dbo].[NoNCompressed Table] Script Date: 05/27/2009 02:24:23 ******/ IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[NoNCompressed Table2]') AND type in (N'U')) DROP TABLE [dbo].[NoNCompressed Table2] GO CREATE TABLE [NoNCompressed Table2] (id int, FName varchar(100), LName varchar(100)) declare @n int set @n=0 while @n<=10000 begin insert into [NoNCompressed Table2] values (1,'Adam','Smith'),(2,'Maria','carter'),(3,'Walter','zenegger') set @n=@n+1 end GO ʹÓÃÏÂÃæµÄSQLÓï¾ä²éѯ¸Ã±íÕ¼ÓõĿռä´óС£º
EXEC sp_spaceused [NONCompressed Table2] ·µ»Ø½á¹û£º
name,rows,reserved,data,index_size,unused NoNCompressed Table,30003 ,968 KB,944 KB,8 KB,16 KB ʹÓÃÏÂÃæµÄALTER TABLEÓï¾äÆôÓñíµÄѹËõ¹¦ÄÜ£º
ALTER TABLE [NoNCompressed Table2] REBUILD WITH (DATA_COMPRESSION = ROW ); È»ºóʹÓÃÏÂÃæµÄSQLÓï¾ä²éѯ±íµÄ¿Õ¼äÕ¼ÓÃÇé¿ö£º
EXEC sp_spaceused [NONCompressed Table2] ·µ»Ø½á¹û£º
name,rows,reserved,data,index_size,unused
NoNCompressed Table2,30003 ,592 KB,560 KB,8 KB,24 KB