最近文章更新
- 1966年生产的广州 珠江 SB6-2型 ..
- HD6870/6850全面评测,让你大饱眼..
- 百万现金刚入门 中国7大奢华私人..
- 罕见4G希捷酷鱼系类万转SCSI服务..
- IBM 6x86MX PR333 CPU
- 采用MC68000 CPU的进口老计算机主..
- 1989年IBM-XT机软驱
- BC3型饱和标准电池拆解
- JUKO ST
- Kingston 品牌的CPU
- YAMAHA 719
- intel 30线 内存条
- intel mmx cpu和主板
- 首款xHCI 1.0正式版标准USB 3.0控..
- 《极品飞车:地下狂飙》纹理MOD视..
- USB接口加扩展子卡:影驰神秘GTX..
- 阿里巴巴将发布浏览器 核心不是W..
- 黄仁勋大秀NVIDIA LOGO纹身
- Google Earth上的奇特卫星图片
- 开火!讯景限量版HD 5970详细测试..
相关文章链接
本类文章排行
最新新闻资讯
本周下载排行
- ArcSoft TotalMedia Theatre 3 P..
- Windows 7 Build 7600 16385 RTM..
- 《姗姗来迟软件光盘+飞扬PE工具箱..
- MSDN Windows 7 RTL 7600 Ultima..
- Windows 7 Home Premium (x86) -..
- Windows Virtual PC (x86) - (Mu..
- MSDN Windows 7 Language Pack X..
- Windows 7 Language Pack (x64) ..
- Windows 7 Starter (x86) - DVD ..
- Windows 7 Professional (x86) -..
- Windows 7 Language Pack (x86) ..
- Windows 7 Home Premium (x64) -..
- Windows XP Mode (x86, x64) - (..
- 7127.0.090507-1820_x86fre_clie..
- DMG2ISO
本月下载排行
- ArcSoft TotalMedia Theatre 3 P..
- Windows 7 Build 7600 16385 RTM..
- 《姗姗来迟软件光盘+飞扬PE工具箱..
- MSDN Windows 7 RTL 7600 Ultima..
- MSDN Windows 7 Language Pack X..
- Windows 7 Home Premium (x86) -..
- Windows 7 Language Pack (x64) ..
- Windows 7 Professional (x86) -..
- 7127.0.090507-1820_x86fre_clie..
- Windows 7 Professional (x64) -..
- Windows 7 Starter (x86) - DVD ..
- Windows Virtual PC (x86) - (Mu..
- Windows 7 Ultimate (x64) - DVD..
- Lenovo Windows 7 Ultimate OEM ..
- Windows 7 Home Premium (x64) -..
- 阅览次数: 文章来源: 原文作者: 整理日期: 2010-07-13
SQL Server 2008 数据压缩功能解析
SQL Server 2008 数据压缩功能解析
1、“数据压缩”有什么用?
简单地说,这以功能使得SOL Server 2008允许在表、索引和分区中执行数据压缩,这样不仅可以节省磁盘空间,而且允许更多数据装入RAM中,提升查询的性能。通过笔者测试发现,在数据仓库的场景中,新的压缩技术可以把表的大小减少到原容量的15%一5O%。可见,这一个功能在实战中还是非常有用的。SQL Server 2008中的数据压缩有两种应用方式,即行压缩和页压缩,下面分别进行解读。
2、行压缩的优与劣
Vardecimal存储格式是在SQL Server 2005 SP2时加入的,它是SOL Server 2008行压缩概念的鼻祖。在SQL Server 2005 SP2之前,decimal类型总是以固定数据存储的。根据值的精确度,每个decimal值都需要5到17字节的空间。Vardecimal把decimal值以一个可变长度的格式进行存储。这种格式把小数值前后的零都去除,可以减少存储所需的空间。
SOL Server 2008数据压缩扩展了这个功能,对所有固定长度的数据类型都进行了处理,包括integer、char和float。现在数据不是以固定大小的字节进行存储,而是用最小所需的字节,你也不需要去修改数据类型。只需要启用行压缩功能,剩下的工作就交给SOL Server 2008企业版去处理吧。
但是,行压缩无法处理XML、BLOB和MAX数据类型。对于开发人员来说,行压缩和页压缩是透明的,如果要使用这个功能,你不需要修改现有的程序。
3、关于页压缩
页压缩既使用了列前缀压缩,又使用了字典压缩。列前缀压缩应用到长度可变的列上,它将一个前缀票据和一个后缀值存储在表的行中。前缀票据的值存储在页头中。前缀票
据仅仅是为页面中的通用前缀值而生成的。字典压缩也把票据值存储在页头中,针对那些固定长度的列,它还在表的行中为页面的常用值存储了一个票据。
4、如何启用压缩?
(1).启用行压缩
如果我们要在指定的表上启用行压缩,可执行以下语句:
CREATE TABLE Alpha(col1 int,col2 char(1000)) WITH (DATA_COMPRESSION = ROW) |
(2).启用页压缩
如果我们要在指定的分区上启用压缩,可执行以下语句:
CREATE TABLE Alpha_Partition(col1 int,col2 char(1000)) ON PartitionScheme(col 1) WITH (DATA_COMPRESSION = PAGE ON) PARTITIONS(1-3) |
(3).修改压缩
如果要把一个现有的索引修改为使用压缩,可执行以下语句:
ALTER INDEX Collndx ON Alpha REBUILD WITH (DATA_C0MPRESSION=PAGE) ALTER INDEX Collndx ON Alpha REBUILD partition = 2 WITH (DATA_COMPRESSION=PAGE) |
5、关于节省空间
执行“数据压缩”能够节省空间,如何查看以及节省空间的大小与什么有关呢?使用SQL Server 2008新的存储过程“sp_estimate_data_compression_savings”可以评估应用数据压缩之后可节省多少空间。而节省空间的大小取决于存储的数据类型。此外,执行“数据压缩” 能够在很大程度上提升查询性能,这是因为经过压缩能够使得更多数据装入RAM中,这样对于提升查询的性能是非常有益的。