2

如何查询具有数据类型 HIERARCHYID 列的表并获取员工下方 X 级别的后代列表?

这是当前的结构:

CREATE TABLE [dbo].[Employees](
    [NodeId] [hierarchyid] NOT NULL,
    [EmployeeId] [int] IDENTITY(1,1) NOT NULL,
    [FirstName] [varchar](120) NULL,
    [MiddleInitial] [varchar](1) NULL,
    [LastName] [varchar](120) NULL,
    [DepartmentId] [int] NULL,
    [Title] [varchar](120) NULL,
    [PhoneNumber] [varchar](20) NULL,
    [IM] [varchar](120) NULL,
    [Photo] [varbinary](max) NULL,
    [Bio] [varchar](400) NULL,
    [Active] [bit] NULL,
    [ManagerId] [int] NULL
)
4

1 回答 1

3

我想在上面添加一点。除了选择树的一个分支外,您通常只需要某个深度的后代。为了实现这一点,许多表使用为“深度”添加一个额外的计算列(类似[Depth] AS (myHierarchy.GetLevel]())。使用这个额外的列,您可以运行如下查询来限制深度。

SELECT @MaxDepth       = 3,

SELECT @theParent      = Hierarchy,
       @theParentDepth = Depth
FROM   myTreeTable T 
WHERE  T.RowID         = @RowID

SELECT    myHierarchy
FROM      myTreeTable T
WHERE     T.myHierarchy.IsDescendantOf(@theParent) = 1  AND
          T.Depth < (@theParentDepth  + @MaxDepth)

请注意,如果您严重依赖计算列(可能与其他一些列组合或包含),您可能想要索引它。

于 2010-07-28T13:35:43.660 回答