oracle递归查询语句(oracle递归查询函数)

   2023-03-19 互联网0
核心提示:众所周知,目前的mysql版本中并不支持直接的递归查询,但是通过递归到迭代转化的思路,还是可以在一句SQL内实现树的递归查询的。这个得益于Mysql允许在SQL语句内使用@变量。以下是示例代码。 创建表格 CREATE TABLE `lf_

oracle递归查询语句(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))
 
标签: 级数 节点 示例
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与爱美生活网(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

点击排行