加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

删除SQL表中的层次数据

发布时间:2020-12-12 16:09:44 所属栏目:MsSql教程 来源:网络整理
导读:我有一个分层数据的表. 一列“ParentId”,其中包含父(parent)的Id(“ID” – 键列) 删除一行时,我想删除所有的子级(所有级别的嵌套). 怎么做? 谢谢 解决方法 当行数不是太大时,erikkallen的递归方法起作用. 以下是使用临时表收集所有子项的替代方法: create
我有一个分层数据的表.
一列“ParentId”,其中包含父(parent)的Id(“ID” – 键列)

删除一行时,我想删除所有的子级(所有级别的嵌套).

怎么做?

谢谢

解决方法

当行数不是太大时,erikkallen的递归方法起作用.

以下是使用临时表收集所有子项的替代方法:

create table #nodes (id int primary key)
insert into #nodes (id) values (@delete_id)
while @@rowcount > 0
    insert into #nodes 
    select distinct child.id 
    from table child
    inner join #nodes parent on child.parentid = parent.id
    where child.id not in (select id from #nodes)

delete
from table
where id in (select id from #nodes)

它从带有@delete_id的行开始,并从那里下降. where语句是为了避免递归;如果你确定没有,你可以离开它.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读