码农刘刘 2019-10-24 16:40 采纳率: 75%
浏览 600
已结题

Oracle递归查询树替换成mysql递归查询树

1.遇到问题(递归查询子节点时有两个pid如何更改)
2.附上oracle代码:(想在mysql做替换)
select * from dataclean_element t start with t.id=#{nodeId} CONNECT BY PR OR t.id in(t.src_id,t.tag_id)

3.报错信息:Subquery returns more than 1 row

4.自己改的mysql问题代码 -> create definer = syjl_test@
%
function getDataCleanElementChildList(rootId int) returns varchar(10000)
BEGIN
DECLARE sTemp VARCHAR(10000);
DECLARE sTempChd VARCHAR(10000);
DECLARE PID VARCHAR(10000);

SET sTemp = '$';
SET sTempChd =cast(rootId as CHAR);

WHILE sTempChd is not null DO
SET sTemp = concat(sTemp,',',sTempChd);
SET PID = (select SRC_ID from DATACLEAN_ELEMENT union select TAG_ID from DATACLEAN_ELEMENT);
SELECT group_concat(id) INTO sTempChd FROM DATACLEAN_ELEMENT where FIND_IN_SET(PID,sTempChd)>0;
END WHILE;
RETURN sTemp;

5.参考博客:https://www.cnblogs.com/fakerblog/p/8372240.html

6.将oracle 递归sql 改为mysql start with CONNECT BY PR OR t.id (t.src_id,t.tag_id)可行方案

  • 写回答

1条回答 默认 最新

  • dabocaiqq 2019-10-24 22:49
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog