SQL Server 2008 引入了“稀疏列”
2007-12-04 09:52:34 来源:WEB开发网核心提示:SQL Server 2008 消除了每个表只能有1024个列的限制,这是通过一个名叫“稀疏列(sparse columns)”的选项来实现的,SQL Server 2008 引入了“稀疏列”,虽然不限制列的个数看起来似乎没有多大用处,但确实曾经有开发人员反对过这种限制,按照Steve Jone
SQL Server 2008 消除了每个表只能有1024个列的限制,这是通过一个名叫“稀疏列(sparse columns)”的选项来实现的。虽然不限制列的个数看起来似乎没有多大用处,但确实曾经有开发人员反对过这种限制。
(稀疏列)一种可能的用途是——在联系人管理系统中,保存一个联系人的大量信息。往往只有很少的用户才会填入所有信息,这就潜在地浪费了大量的空间。(以前)通用的解决方案是,创建一个“实体-属性-值”表,这个表保存了联系人编号、属性的名称或关键字以及属性的值。
但“实体-属性 -值”表也存在一些问题。一个问题是,这种表的大小要比普通表增长得快,可能会导致一些严重的性能问题。另外,这种表不具有严格的关系。转化一个“实体 -属性-值”表到一个普通表需要花费大量的时间,尤其在SQL Server 2005引入PIVOT关键词之前。
通过使用稀疏列,列数量的限制和相关的空间要求问题都被根除了。按照Steve Jones的说法,SQL Server 2008理论上能够支持“成千上万的稀疏列”。不过目前关于这个特性的细节还不多。
Bob Beauchemin给出了一个使用该新语法的例子:
CREATETABLEproducts(product_numint,item_numint,pricedecimal(7,2),...,
colorchar(5)SPARSE,widthfloatSPARSE...)
- ››SQL Server 2008 R2 下如何清理数据库日志文件
- ››sqlite 存取中文的解决方法
- ››SQL2005、2008、2000 清空删除日志
- ››SQL Server 2005和SQL Server 2000数据的相互导入...
- ››sql server 2008 在安装了活动目录以后无法启动服...
- ››sqlserver 每30分自动生成一次
- ››sqlite 数据库 对 BOOL型 数据的插入处理正确用法...
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
更多精彩
赞助商链接