sql 语句查所有父级

常见问题,给一个记录ID,查出它的所有父级,直到顶级

使用SMSS,sql server,找到一个办法.

思路是分两步,先循环找到所有父级的ID,再用IN查出所有父级

列说明  ID=PK  ParentId = 上级ID  ParentId = 0 表示到顶级了

SQL语句 :

DECLARE @childrenId VARCHAR(32)     -- 要查找这个ID的所有父级
DECLARE @1parentIds VARCHAR(max) -- 所有父级的ID列表,最终拼成IN的条件.效果如: '111','222','333'

SET @1parentIds = ''''+@childrenId+''''      -- 也包含自己,一直到父级

WHILE @childrenId!='0'         -- 如果父级ID不是0就继续查找
BEGIN
  SELECT @childrenId = ParentId FROM [table] WHERE  Id=@childrenId -- 根据ID找到这个记录,将它的父ID赋值,这个父ID作为下一级的子ID查找
  SET @1parentIds= @1parentIds + ',' + '''' + @childrenId + ''''                    -- 拼接这个父ID
END

-- 由于拼接的字符串不能做IN的参数,所以想这个办法将整个SQL拼成再执行之.

EXEC('SELECT * FROM [table] WHERE Id IN (' + @1parentIds + ')'+'ORDER by Id')

转载于:https://www.cnblogs.com/mirrortom/p/8931190.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值