在 hierarchyid 实现之前,大家使用 BigClass、SmallClass 或 ParentId 一类的方法实现层级,其缺陷就是要么层级数被限定,要么就是无法多层级索引。
SQL Server 2008 中有一个类型叫 hierarchyid,用来实现层级目录功能的,可以非常方便地查找祖先、父级、兄弟、儿子、后代。
方法
hierarchyid 的方法是区分大小写的。
静态方法
静态方法前面用冒号。
实例方法
实例方法前面用点号,可以对 hierarchyid 字段、变量使用。
示例、更新 hierarchyid
如下,记录插入后,使用如下代码更新该记录的 hierarchyid,这里 hierarchyid 的字段名称为 PathNode。
首先查找当前记录的父记录,如果父记录不存在,则使用 HierarchyId::GetRoot() 作为父记录的 hierarchyid。
再查找记录两个相邻的兄弟(实际上,上面的示例中由于是新插入的,所以“弟弟” @child2 并不存在),GetDescendant 就会根据父 hierarchyid 和两个兄弟的 hierarchyid 自动给出当前记录的 hierarchyid 值。