| C114首页 | 新闻 | 技术 | 市场 | 会展 | 黄页 | 人物 | 3G | WiMax | LTE | FTTH | IPTV | IP通信 | NGN 通信人家园 | 通信人博客 | 通信商情网 | 通信人才网 | English |
|
微软SQL Server 2008数据库中的新数据类型
( 2008/10/13 15:58 )
对于关系型数据库来说,表现树状的层次结构始终是一个问题。微软在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来获得树状结构的合适示例。事实上,与它有关的所有东西都更像是一些命令,而不是基于集合的操作。
|
·SQL Server数据库查询速度慢原因及优化方法 (12-3) ·Java基础:常用的JDBC连接数据库方法大全 (12-3) ·分享:IBM DB2 数据库下一版本功能抢先看 (11-27) ·中联通完善基础设施数据库 为共建共享铺路 (11-24) ·工信部将整合部内资源 建知识产权数据库 (11-20) 热议文章·广电总局张海涛:以CMMB为基础实现三网融合 (12-5) 评:广电提出基于CMMB的三网融合,从技术上看没有太多问题,但实际应用确需要争取电信... ·短信网内网间突破差价藩篱 贯彻就低不就高原则 (12-4) ·ICT业务发展良策 (12-4) ·关于CDMA发展危机的三大理由 (12-4) ·重组后的中国联通,何以对抗即将到来的混战 (12-3) ·传新联通鼓励员工内退,变相减人 (12-3) ·中国电信“三不新政” 不改号不换卡无需换终端 (12-2) ·诺基亚不是TD的救世主 (12-2) ·实时音频方案的演变与设计挑战 (12-5) ·摩托罗拉CDMA EV-DO解决方案 (12-5) ·EPON的光接入网解决方案 (12-5) ·Virtex-5 FPGA设计Gbps无线通信基站 (12-5) ·数字无线网络技术在实时无损检测系统中的应用 (12-5) ·开启大容量传送网的新纪元 (12-5) ·次贷危机下,LTE是个新谎言 (10-29) ·全球通信业面临金融危机冲击 对中国企业或利大于弊 (10-27) ·宽带市场不宜“非对称管制” (9-17) ·从校园竞争看重组后电信运营商竞争力对比 (9-8) |
|||||||||||||||
|