oracle递归查询语句 示例代码已列出 爱好者可以自行参考


(资料图片仅供参考)

众所周知,目前的mysql版本中并不支持直接的递归查询,但是通过递归到迭代转化的思路,还是可以在一句SQL内实现树的递归查询的。这个得益于Mysql允许在SQL语句内使用@变量。以下是示例代码。

创建表格

CREATE TABLE `lf_ctrl_trade` (    `TRADEID` int , -- 节点ID    `nodename` varchar (60), -- 节点名称    `PARENTID` int  -- 节点父ID); 

方案一:

 SELECT TRADEID AS ID,PARENTID AS 父ID ,levels AS 父到子之间级数, paths AS 父到子路径 FROM (     SELECT TRADEID,PARENTID,     @le:= IF (PARENTID = 0 ,0,           IF( LOCATE( CONCAT("|",PARENTID,":"),@pathlevel)   > 0  ,                        SUBSTRING_INDEX( SUBSTRING_INDEX(@pathlevel,CONCAT("|",PARENTID,":"),-1),"|",1) +1        ,@le+1) ) levels     , @pathlevel:= CONCAT(@pathlevel,"|",TRADEID,":", @le ,"|") pathlevel      , @pathnodes:= IF( PARENTID =0,",0",            CONCAT_WS(",",           IF( LOCATE( CONCAT("|",PARENTID,":"),@pathall) > 0  ,                SUBSTRING_INDEX( SUBSTRING_INDEX(@pathall,CONCAT("|",PARENTID,":"),-1),"|",1)              ,@pathnodes ) ,PARENTID  ) )paths    ,@pathall:=CONCAT(@pathall,"|",TRADEID,":", @pathnodes ,"|") pathall         FROM  lf_ctrl_trade,     (SELECT @le:=0,@pathlevel:="", @pathall:="",@pathnodes:="") vv    ORDER BY  PARENTID,TRADEID    ) srcORDER BY TRADEID

方案二:

创建函数

DROP FUNCTION IF EXISTS queryChildrenTrade;CREATE FUNCTION `queryChildrenTrade` (myid INT)RETURNS VARCHAR(4000)BEGINDECLARE sTemp VARCHAR(4000);DECLARE sTempChd VARCHAR(4000); SET sTemp = "$";SET sTempChd = cast(myid as char); WHILE sTempChd is not NULL DOSET sTemp = CONCAT(sTemp,",",sTempChd);SELECT group_concat(TRADEID) INTO sTempChd FROM lf_ctrl_trade where FIND_IN_SET(PARENTID,sTempChd)>0;END WHILE;return sTemp;END;

如何查询:

select * from lf_ctrl_trade where FIND_IN_SET(TRADEID, queryChildrenTrade(3000))
推荐DIY文章
联想笔记本怎么进入BIOS 为了方便大家查阅和操作本文已写明所有操作过程
自己安装win7系统步骤是什么 如果是新硬盘可以使用U盘启动盘安装
win10系统中steam社区提示错误代码-118 详细解决方法将在本文呈现|环球新动态
win7各版本激活码大全出炉 希望本教程对大家激活系统有所帮助 _全球最资讯
win10系统game for windows live不兼容 只需要手动下载并安装 xliveredist即可 |世界讯息
win10系统开机黑屏进不去的原因 一般情况下是因为Explorer资源管理器出现问题
精彩新闻

超前放送