4

是否可以按层次结构 ID 对层次结构中的 sql 数据进行排序,然后按字母顺序对每个级别进行排序?

假设我们有一个员工表,它根据员工 ID 列出组织层次结构

Bob (5) 有 Phil (17) 和 Charlie (28) 向他汇报,而 Josie (6) 有 Tyler (15) 和 Mike (56) 向她汇报。

如果您按 HierarchyID 对其进行排序,它将如下所示:

Bob (/5/)
--Phil (/5/17/)
--Charlie (/5/28/)
Josie (/6/)
--Tyler (/6/15/)
--Mike (/6/56 /)

但让它看起来可能更有意义

鲍勃—— 查理——菲尔乔西
—— 迈克 —— 泰勒



这是否可能而不会变得过于复杂?

4

3 回答 3

2

——这行得通吗?这取自SQL Server 2008 中的排序树和其他列

DECLARE @table TABLE (id INT NOT NULL PRIMARY KEY, name NVARCHAR(4000) NOT NULL, path HIERARCHYID)

INSERT
INTO    @table
VALUES  
        (1, 'People', '/'),
        (2, 'Girls', '/1/'),
        (3, 'Boys', '/2/'),
        (4, 'Zoey', '/1/1/'),
        (5, 'Kate', '/1/2/'),
        (6, 'Monica', '/1/3/'),
        (7, 'Mark', '/2/1/'),
        (8, 'David', '/2/2/')

;WITH   q AS
        (
        SELECT  *, HIERARCHYID::Parse('/') AS newpath
        FROM    @table
        WHERE   path = HIERARCHYID::GetRoot()
        UNION ALL
        SELECT  t.*, HIERARCHYID::Parse(q.newpath.ToString() + CAST(ROW_NUMBER() OVER (ORDER BY t.name) AS NVARCHAR(MAX)) + '/')
        FROM    q
        JOIN    @table t
        ON      t.path.IsDescendantOf(q.path) = 1
                AND t.path.GetLevel() = q.path.GetLevel() + 1
        )
SELECT  replicate(convert(nvarchar, '-'), q.path.GetLevel()) + q.name /*+ '(' + q.newpath.ToString() + ')'*/
FROM    q
ORDER BY
        newpath
于 2012-01-18T04:28:21.663 回答
2

这是我找到的解决方案

declare @oldId hierarchyid, @newId hierarchyid, @parent hierarchyid

select @oldId = id_node, @parent = id_node.GetAncestor(1)
from gbs.T_Hierarchy_Activities ha
where ID = @ID_Object

select @newId = @oldId.GetReparentedValue(@oldId, ID_Node) from (
    select row_number() over(order by id_node) rn, id_node
    from gbs.T_Hierarchy_Activities ha
        cross join (select * from common.FX_Permissions() where ID_Feature = 10) p
    where ID_Node.IsDescendantOf(@oldId.GetAncestor(1)) = 1
        and ID_Level = @oldId.GetLevel()
        and ha.ID_Office = p.ID_Office
) a
where rn = @NewPosition

update gbs.T_Hierarchy_Activities
set ID_Node = case when ID_Node = @oldId then @newId else @oldId end
where ID_Node in (@oldId, @newId)
于 2012-10-18T09:41:38.950 回答
0

除非我误解了某些东西,否则您可以在ORDER BY子句中添加一个辅助排序字段。例如:

SELECT * FROM Employees ORDER BY HierarchyID, Name
于 2012-01-17T17:51:47.137 回答