java MySQL 查询所有子级(不包含自己)

这篇博客分享了一段Java SQL代码,用于从xun_village_region表中查询指定父ID的所有子级记录,但不包括自身。代码利用了MySQL的find_in_set和if函数来实现层级遍历,适用于需要递归查询子节点的场景。
摘要由CSDN通过智能技术生成

java MySQL 查询所有子级(不包含自己)

别的不说上源码

parent_id :上级id
xun_village_region :表名

这条SQL只能查询到自己的下级

 SELECT
            t3.*
        FROM
            (
                SELECT
                    t1.*,
                    IF
                        ( find_in_set( parent_id, @pids ) > 0, @pids := concat( @pids, ',', id ), 0 ) AS ischild
                FROM
                        ( SELECT * FROM xun_village_region t where is_delete = 1 ORDER BY parent_id, id ) t1,
                        ( SELECT @pids := #{parentId} ) t2
            ) t3
        WHERE
            ischild != 0

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值