我将如何仅查询“仅叶子节点”的记录 (即没有孩子)?
我尝试过这样的查询:
select *
from TableA tt
where tt.HierarchyId.GetDescendant(null, null) not in
(
Select t.HierarchyId
from TableA t
)
但是这似乎仍然会返回一些有孩子的节点。
我使用的是内置的hierarchyid数据类型(ms sqlserver的一部分)
答案 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;