人大金仓kingbase8的sql递归写法

背景:公司要迁移项目,原来项目是用mysql数据库,为了安全性需要把mysql数据库替换成国产数据库(人大金仓的kingbase8),由于两个数据库的兼容性问题,迁移应用后发现有些sql不能直接在kingbase上运行,需要修改sql的语法符合kingbase的语法要求。

表关系:部门表(sysmgr_dept),部门用户映射表(sysmgr_dept_user_mid),需要查询出来的数据结构为:按父子关系递归查询出该用户所属部门及其下属的所有部门名称集合。
原来在mysql中的写法:

SELECT
            t2.deptname
        FROM
            (
                SELECT
                    @r AS _id,
                (SELECT @r := parentid FROM sysmgr_dept WHERE id = _id ) AS parentid,
                @l :=@l + 1 AS lvl
                FROM
                    (
                    SELECT
                    @r := (SELECT
                    t.DEPTID
                    FROM
                    sysmgr_dept_user_mid t
                    WHERE
                    t.USERID = '1273228086501244928'
                    AND t.ISMASTER = '1'
                    LIMIT 1
                    ) ,@l := 0
                    ) vars,
                    sysmgr_dept h
                WHERE
                    @r <> 0
            ) t1
                JOIN sysmgr_dept t2 ON t1._id = t2.id
        ORDER BY
            t1.lvl DESC`

改成符合人大金仓后的写法:

SELECT
            t2.deptname
        FROM
            (
                WITH RECURSIVE ptemp as (
                    SELECT id as _id,parentid, 1 as lvl
                    from sysmgr_dept where id = (SELECT
                                                        t.DEPTID
                                                    FROM
                                                        sysmgr_dept_user_mid t
                                                    WHERE
                                                        t.USERID = '1273228086501244928'
                                                      AND t.ISMASTER = '1'
                    LIMIT 1)
        union all
        SELECT csd.id as _id,csd.parentid, ptemp.lvl + 1 from sysmgr_dept csd INNER JOIN ptemp on csd.id = ptemp.parentid
            ) SELECT * from ptemp ORDER BY ptemp.lvl
            ) t1
                JOIN sysmgr_dept t2 ON t1._id = t2.id
        ORDER BY
            t1.lvl DESC

两者的输出如下:
在这里插入图片描述
中间结构如下:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值