使用hierarchyid查找所有叶节点记录

时间:2012-05-22 02:02:24

标签: sql-server sql-server-2008 hierarchyid

我将如何仅查询“仅叶子节点”的记录 (即没有孩子)?

我尝试过这样的查询:

select *
from TableA tt
where tt.HierarchyId.GetDescendant(null, null) not in 
(
    Select  t.HierarchyId
    from TableA t
)

但是这似乎仍然会返回一些有孩子的节点。

我使用的是内置的hierarchyid数据类型(ms sqlserver的一部分)

1 个答案:

答案 0 :(得分:6)

SELECT A.HieracrchyId, A.HierarchyId.ToString()
  FROM dbo.TableA AS A 
  LEFT OUTER JOIN dbo.TableA AS B
  ON A.HierarchyId = B.HierarchyId.GetAncestor(1)
  WHERE B.HierarchyId IS NULL;