mysql通過@變量實(shí)現(xiàn)遞歸詳細(xì)實(shí)例
1. 測試表結(jié)構(gòu)
create table demo ( id varchar(100) not null primary key, parentId varchar(100) not null ); -- 測試數(shù)據(jù) INSERT INTO demo (ID, parentID) VALUES ('1', '0'); INSERT INTO demo (ID, parentID) VALUES ('10', '9'); INSERT INTO demo (ID, parentID) VALUES ('11', '9'); INSERT INTO demo (ID, parentID) VALUES ('2', '1'); INSERT INTO demo (ID, parentID) VALUES ('3', '2'); INSERT INTO demo (ID, parentID) VALUES ('4', '3'); INSERT INTO demo (ID, parentID) VALUES ('5', '4'); INSERT INTO demo (ID, parentID) VALUES ('6', '5'); INSERT INTO demo (ID, parentID) VALUES ('7', '6'); INSERT INTO demo (ID, parentID) VALUES ('8', '1'); INSERT INTO demo (ID, parentID) VALUES ('9', '1');
2. 向下遞歸(包括自己)
-- 向下遞歸 par即為遞歸查詢出來的所有id SELECT @par AS par, (SELECT @par := GROUP_CONCAT(id) FROM demo WHERE FIND_IN_SET(parentid, @par)) AS son FROM demo_userm, (SELECT @par := '1') T WHERE @par IS NOT NULL; 查詢結(jié)果: | par | son | | 1 | 2,8,9 | | 2,8,9 | 10,11,3 | | 10 ,11,3 | 4 | | 4 | 5 | | 5 | 6 | | 6 | 7 | | 7 | NULL |
3.向下遞歸(不包括自己)
-- 向下遞歸 par即為遞歸查詢出來的所有id SELECT @par AS par, (SELECT @par := GROUP_CONCAT(id) FROM demo WHERE FIND_IN_SET(parentid, @par)) AS son FROM demo_userm, (SELECT @par := '1') T WHERE @par IS NOT NULL and @par != '1'; 查詢結(jié)果: | par | son | | 2,8,9 | 10,11,3 | | 10 ,11,3 | 4 | | 4 | 5 | | 5 | 6 | | 6 | 7 | | 7 | NULL |
4. 向下遞歸可能存在問題,修正優(yōu)化:
-- 如果存在 par = 51016 并且 son = 51016 , 那么會出現(xiàn)問題,多出許多數(shù)據(jù) SELECT @par AS par, (SELECT @par := GROUP_CONCAT(distinct ORG_REFNO) FROM gis_udp_bank WHERE FIND_IN_SET(PNBRN_ORG_REFNO, @par)) AS son FROM gis_udp_bank, (SELECT @par := '51016') T WHERE @par IS NOT NULL; -- 優(yōu)化后:后面家條件: !FIND_IN_SET(ORG_REFNO, @par) SELECT @par AS par, (SELECT @par := GROUP_CONCAT(distinct ORG_REFNO) FROM gis_udp_bank WHERE FIND_IN_SET(PNBRN_ORG_REFNO, @par) and !FIND_IN_SET(ORG_REFNO, @par) ) AS son FROM gis_udp_bank, (SELECT @par := '51016') T WHERE @par IS NOT NULL;
5. 向上遞歸
SELECT @par AS par, (SELECT @par := GROUP_CONCAT(NAME) FROM demo_userm WHERE LOGONID = @par) AS son FROM demo_userm, (SELECT @par := '10') T WHERE @par IS NOT NULL; par即為遞歸查詢結(jié)果 查詢結(jié)果: | par | son | | 10 | 9 | | 9 | 1 | | 1 | 0 | | 0 | NULL|
所用函數(shù)介紹:
1、GROUP_CONCAT([distinct] colName)
一般用于取ID集合。 select * from demo_userm t where NAME = 1; | LOGONID | NAME | | 2 | 1 | | 8 | 1 | | 9 | 1 | select GROUP_CONCAT(LOGONID) from demo_userm t where NAME = 1; | GROUP\_CONCAT\(LOGONID\) | | 2,8,9 | -- 不去重取name集合 select GROUP_CONCAT(NAME) from demo_userm t where NAME in (1,2,3,4,5,6,7); | GROUP\_CONCAT\(NAME\) | | 1,2,3,4,5,6,1,1 | -- 去重再取name集合 select GROUP_CONCAT(distinct NAME) from demo_userm t where NAME in (1,2,3,4,5,6,7); | GROUP\_CONCAT\(distinct NAME\) | | 1,2,3,4,5,6 |
2、FIND_IN_SET(colName, strs)
select * from demo_userm where FIND_IN_SET(LOGONID, ('1,2,3,4')); | LOGONID | NAME | | 1 | 0 | | 2 | 1 | | 3 | 2 | | 4 | 3 | select * from demo_userm where FIND_IN_SET(LOGONID, (select GROUP_CONCAT(LOGONID) from demo_userm t where NAME = 1)); | LOGONID | NAME | | 2 | 1 | | 8 | 1 | | 9 | 1 |
3、#@是用戶變量,@@是系統(tǒng)變量。
用戶變量賦值有兩種方式: 一種是直接用"=“號,另一種是用”:=“號。
其區(qū)別在于:
使用set命令對用戶變量進(jìn)行賦值時(shí),兩種方式都可以使用; # 用select語句時(shí),只能用”:=“方式,因?yàn)閟elect語句中,”="號被看作是比較操作符。
總結(jié)
到此這篇關(guān)于mysql通過@變量實(shí)現(xiàn)遞歸的文章就介紹到這了,更多相關(guān)mysql @變量實(shí)現(xiàn)遞歸內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL數(shù)據(jù)庫實(shí)現(xiàn)高可用架構(gòu)之MHA的實(shí)戰(zhàn)
本文主要介紹了MySQL數(shù)據(jù)庫實(shí)現(xiàn)高可用架構(gòu)之MHA的實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02MySQL數(shù)據(jù)庫INNODB表損壞修復(fù)處理過程分享
突然收到MySQL報(bào)警,從庫的數(shù)據(jù)庫掛了,一直在不停的重啟,打開錯(cuò)誤日志,發(fā)現(xiàn)有張表壞了。innodb表損壞不能通過repair table 等修復(fù)myisam的命令操作。現(xiàn)在記錄下解決過程2013-08-08解析mysql數(shù)據(jù)庫還原錯(cuò)誤:(mysql Error Code: 1005 errno 121)
本篇文章是對mysql數(shù)據(jù)庫還原錯(cuò)誤:(mysql Error Code: 1005 errno 121)的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06mysql如何統(tǒng)計(jì)同一字段不同值的個(gè)數(shù)
這篇文章主要介紹了mysql如何統(tǒng)計(jì)同一字段不同值的個(gè)數(shù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11MySQL單表多關(guān)鍵字模糊查詢的實(shí)現(xiàn)方法
MySQL單表多關(guān)鍵字模糊查詢實(shí)現(xiàn)方法是很多人都非常想知道的一個(gè)問題,那么,究竟采用什么方法,才能實(shí)現(xiàn)MySQL單表多關(guān)鍵字模糊查詢呢?2011-03-03