首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >选择Id列表中的顶级parentId,如果所有parentId顶部相同,则返回行

选择Id列表中的顶级parentId,如果所有parentId顶部相同,则返回行
EN

Stack Overflow用户
提问于 2018-08-14 09:22:16
回答 1查看 53关注 0票数 0

我要把我想要的剧本组合成一个:

代码语言:javascript
复制
SELECT [CategoryId] FROM [dbo].[Unit] where Id in (716,724) 

代码语言:javascript
复制
DECLARE @Id INT = 15

;WITH cteGetRootID
As
(

    SELECT
        Id, [Name], ParentId, 1 AS CodePosition
    FROM
        Category WHERE Id = @Id
    UNION All
    SELECT
        ic.Id, ic.[Name], ic.ParentId, CodePosition + 1
    FROM Category ic
    INNER JOIN cteGetRootID cte ON ic.Id = cte.ParentId
)
SELECT  top 1 Id, [Name]  FROM cteGetRootID
ORDER BY CodePosition desc

我希望对第一部分的所有结果执行低代码,如果所有的根都具有相同的根类型,那么我希望从dbo.Unit (716,724)中选择从其中的Id中选择dbo.Unit。

希望它能使人感觉到

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-14 09:37:09

您可以在第一次选择联合时使用join介于dbo.Unitdbo.Category之间:

代码语言:javascript
复制
;WITH cteGetRootID
As
(
    SELECT
        c.Id, c.[Name], c.ParentId, 1 AS CodePosition
    FROM
        Category c 
            INNER JOIN  [dbo].[Unit] u on u.CategoryID = c.Id
    WHERE u.Id in (716,724) 
    UNION All
    SELECT
        ic.Id, ic.[Name], ic.ParentId, CodePosition + 1
    FROM Category ic 
             INNER JOIN cteGetRootID cte ON ic.Id = cte.ParentId
)
SELECT  top 1 Id, [Name]  FROM cteGetRootID
ORDER BY CodePosition desc
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51838027

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档