SQL Server中的新数据类型:HierarchyId

对于关系型数据库来说,表现树状的层次结构始终是一个问题。微软在Sql Server 2005中首次尝试了解决这个问题,那就是被称之为通用数据表表达式( Common Table Expressions,CTE)的实现方式。

尽管CTE在现有的数据库架构中运行良好,微软找到了一种将此类层次结构作为头等概念来使用的方式。因此为了实现这种效果,他们在SQL Server 2008中提出了一种“HierarchId”数据类型。

在传统的层次结构中,一条记录仅仅储存了一个指向它父记录的引用,这使得一条记录能够获得它在层次结构中的相对位置,而不是绝对位置。改变某条记录的父数据行引用是一个原子更新操作,它不会影响到该记录的任何子记录。

一个HierarchyId类型的字段储存了记录在层次结构中的准确位置。Denny Cherry提供了一个例子,其中展示了0x、0x58以及0x5AC0三个值,它们的字符串表现形式分别为“/”,“/1/”和“/1/1/”。这就引发了有关一致性和性能方面的问题,尤其是父记录被改变的时候。Ravi S.Maniam建议在改变父记录操作不频繁的情况下使用这种设计方式。

与HierarchyId类型同时出现的还有一系列函数。GetAncestor和GetDescendant方法可以用来遍历树。ToString和Parse方法用于HierarchyId类型二进制与字符串表现形式之前的转换。有些古怪的是,随之而来的还有用于支持BinaryReader与BinaryWriter的一些方法。

再来回头看看GetDescendant,这是一个有些古怪的方法。它实际上不返回那些子记录,而是返回那些潜在的子节点的位置。向树中插入一个新的记录时,我们必需调用GetDescendant方法来获得指定父记录的最后一个子节点的位置,然后才能获得紧跟着该位置之后的空隙。

迄今为止还没有使用T-SQL来获得树状结构的合适示例。事实上,与它有关的所有东西都更像是一些命令,而不是基于基于集合的操作。





转载自:http://www.infoq.com/cn/news/2007/12/HierarchyId



前一篇:SQL Server 2008和T-SQL新功能         tag:SQL Server 2008

下一篇:SQL Server 2008中的数据类型         tag:SQL Server 2008,数据类型


相关文章:

微软预先展示"Server 2008"五大版本tag:
解析SQL Server 2008 数据仓库tag:SQL Server 2008,数据仓库,商业智能,SSIS
SQL Server 2008对T-SQL语言的增强(1)tag:SQL Server 2008,T-SQL
SQL Server 2008对T-SQL语言的增强(2)tag:SQL Server 2008,T-SQL
SQL Server 2008对T-SQL语言的增强(3)tag:SQL Server 2008,T-SQL
SQL Server 2008 Reporting Service架构tag:SQL Server 2008,Reporting Service
Visual Studio 2008中的SQL数据库发布tag:Visual Studio 2008,数据库,Visual Studio 2008
带你轻松接触SQL Server 2008-- Katmaitag:SQL Server 2008,Katmai,商业智能
SQL Server 2008四项新特性概述tag:SQL Server 2008,集成服务,分析服务,SSAS,报表服务
解读SQL Server 2008的新语句MERGEtag:SQL Server 2008,MERGE
解析SQL Server 2008在线事务处理功能tag:SQL Server 2008,在线事务处理,OLTP
解析SQL Server 2008商业智能tag:SQL Server 2008,商业智能,报表解决方案,OLAP,
SQL Server 2008精妙之处tag:SQL Server 2008,仪表盘
理解SQL Server 2005 Reporting Servicetag:SQL Server 2005,Reporting Service,报表
ADOMDConnection对象tag:ADOMD.Net,ADOMDConnection,Analysis Services
关于OLAPtag:OLAP,Analysis Services,Cube,OWC
Microsoft数据仓库架构tag:数据仓库,Analysis Services,立方体,FoodMart
如何使用MDX编写同比和环比tag:mdx,BI,商业智能,Analysis Services,同比,环比
SQL Server 2005的开发新特性介绍tag:SQL Server 2005
我看BI在中国tag:BI,报表,数据分析,OLAP,SQL Server Reporting Services
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值