Sql Иерархия ID Сортировка по уровню

Можно ли отсортировать данные sql в иерархии по их идентификатору иерархии, а затем для каждого уровня сортировать их по алфавиту?

Допустим, у нас есть таблица сотрудников, в которой перечислены организационные иерархии на основе идентификатора сотрудников

У вас есть Боб (5), у которого есть Фил (17) и Чарли (28), и Джози (6) имеет Тайлера (15) и Майка (56), подчиняющихся ей.

Если вы отсортируете его по HierarchyID, оно будет выглядеть так:

Боб (/5 /)
--Phil (/5/17 /)
--Чарли (/5/28 /)
Джози (/6 /)
--Tyler (/6/15 /)
--Майк (/6/56 /)

Но, вероятно, было бы более разумно, чтобы это выглядело как

Боб
--Charlie
--Phil
Джози
--Mike
--Tyler

Возможно ли это, не слишком запутанно?

4 голоса | спросил Mike Kshymensky 17 Jpm1000000pmTue, 17 Jan 2012 21:47:03 +040012 2012, 21:47:03

3 ответа


0

- Будет ли это работать? это взято из дерева сортировки с другим столбцом в 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
ответил Jason Dam 18 Jam1000000amWed, 18 Jan 2012 08:28:21 +040012 2012, 08:28:21
0

Это решение, которое я нашел

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)
ответил Marco Panino 18 +04002012-10-18T13:41:38+04:00312012bEurope/MoscowThu, 18 Oct 2012 13:41:38 +0400 2012, 13:41:38
0

Если я что-то не так понимаю, вы можете просто добавить вторичное поле сортировки в предложение ORDER BY. Например:

SELECT * FROM Employees ORDER BY HierarchyID, Name
ответил Ben Hoffstein 17 Jpm1000000pmTue, 17 Jan 2012 21:51:47 +040012 2012, 21:51:47

Похожие вопросы

Популярные теги

security × 330linux × 316macos × 2827 × 268performance × 244command-line × 241sql-server × 235joomla-3.x × 222java × 189c++ × 186windows × 180cisco × 168bash × 158c# × 142gmail × 139arduino-uno × 139javascript × 134ssh × 133seo × 132mysql × 132