mysql 递归实现树形_Mysql实现树形递归查询
最近在做項(xiàng)目遷移,Oracle版本的遷到Mysql版本,遇到有些oracle的函數(shù),mysql并沒(méi)有,所以就只好想自定義函數(shù)或者找到替換函數(shù)的方法進(jìn)行改造。
Oracle遞歸查詢(xún)
oracle實(shí)現(xiàn)遞歸查詢(xún)的話,就可以使用start with ... connect by
connect by遞歸查詢(xún)基本語(yǔ)法是:
select 1 from 表格 start with ... connect by prior id = pId
start with:表示以什么為根節(jié)點(diǎn),不加限制可以寫(xiě)1=1,要以id為123的節(jié)點(diǎn)為根節(jié)點(diǎn),就寫(xiě)為start with id =123
connect by:connect by是必須的,start with有些情況是可以省略的,或者直接start with 1=1不加限制
prior:prior關(guān)鍵字可以放在等號(hào)的前面,也可以放在等號(hào)的后面,表示的意義是不一樣的,比如 prior id = pid,就表示pid就是這條記錄的根節(jié)點(diǎn)了
Oracle方面的實(shí)現(xiàn)
select distinct u.unit_code,
u.unit_name,
u.unit_tel,
u.para_unit_code
from lzcity_approve_unit_info u
start with 1 = 1
and u.unit_code = #{unitCode}
and u.unit_name like '%'|| #{unitName} ||'%'
connect by prior u.unit_code = u.para_unit_code
and u.unit_code <>u.para_unit_code
Mysql遞歸查詢(xún)
下面主要介紹Mysql方面的實(shí)現(xiàn),Mysql并沒(méi)有提供類(lèi)似函數(shù),所以只能通過(guò)自定義函數(shù)實(shí)現(xiàn),網(wǎng)上很多這種資料,不過(guò)已經(jīng)不知道那篇是原創(chuàng)了,這篇博客寫(xiě)的不錯(cuò),https://www.2cto.com/database/201209/152513.html, 下面我也是用作者提供的方法實(shí)現(xiàn)自己的,先感謝作者的分享
這里借用作者提供的自定義函數(shù),再加上Find_in_set函數(shù) find_in_set(u.unit_code,getunitChildList(#{unitCode})),getunitChildList是自定義函數(shù)
select distinct u.unit_code,
u.unit_name,
u.unit_tel,
u.para_unit_code
from t_unit_info u
and find_in_set(u.unit_code,getunitChildList(#{unitCode}))
and u.unit_name like concat('%', #{unitName} ,'%')
getUnitChildList自定義函數(shù)
DELIMITER $$
USE `gd_base`$$
DROP FUNCTION IF EXISTS `getUnitChildList`$$
CREATE DEFINER=`root`@`%` FUNCTION `getUnitChildList`(rootId INT) RETURNS VARCHAR(1000) CHARSET utf8
BEGIN
DECLARE sChildList VARCHAR(1000);
DECLARE sChildTemp VARCHAR(1000);
SET sChildTemp =CAST(rootId AS CHAR);
WHILE sChildTemp IS NOT NULL DO
IF (sChildList IS NOT NULL) THEN
SET sChildList = CONCAT(sChildList,',',sChildTemp);
ELSE
SET sChildList = CONCAT(sChildTemp);
END IF;
SELECT GROUP_CONCAT(unit_code) INTO sChildTemp FROM LZCITY_APPROVE_UNIT_INFO WHERE FIND_IN_SET(para_unit_code,sChildTemp)>0;
END WHILE;
RETURN sChildList;
END$$
DELIMITER ;
總結(jié)
以上是生活随笔為你收集整理的mysql 递归实现树形_Mysql实现树形递归查询的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 建行信用卡额度怎么提升 四点技巧让你额度
- 下一篇: matlab调用哈希表,ros与matl