婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL之遞歸小問題

MySQL之遞歸小問題

熱門標簽:沈陽電銷外呼系統原理是什么 地圖標注人員兼職 扎樣申請400電話 聊城智能外呼系統運營商 電子地圖標注電話 ps制作地圖標注gif 寧波企業外呼系統收費 上海智能外呼系統代理商 成都優派外呼系統

mysql本身不支持遞歸語法,但可通過自連接變相實現一些簡單的遞歸

--遞歸小方法:臨時表和普通表的不同方法
--這題使用的是2次臨時表查詢父節點的遞歸 

drop table if exists test;
create table test(
id varchar(100),
name varchar(20),
parentid varchar(100)
);
insert test select
'13ed38f1-3c24-dd81-492f-673686dff0f3', '大學教師', '37e2ea0a-1c31-3412-455a-5e60b8395f7d' union all select 
'1ce203ac-ee34-b902-6c10-c806f0f52876','小學教師', '37e2ea0a-1c31-3412-455a-5e60b8395f7d' union all select 
'37e2ea0a-1c31-3412-455a-5e60b8395f7d', '教師' ,      null                union all select 
'c877b7ea-4ed3-f472-9527-53e1618cb1dc', '高數老師', '13ed38f1-3c24-dd81-492f-673686dff0f3' union all select 
'ce50a471-2955-00fa-2fb7-198f6b45b1bd', '中學教師', '37e2ea0a-1c31-3412-455a-5e60b8395f7d';
 
delimiter $$
 
create procedure usp_ser(in idd varchar(100))
begin
declare lev int;
set lev=1;
drop table if exists tmp1;
drop table if exists tmp2;
CREATE TEMPORARY TABLE tmp1(id varchar(100),name varchar(20),parentid varchar(100),levv int);
CREATE TEMPORARY TABLE tmp2(pid varchar(100));
insert tmp2 select parentid from test where id=idd;
insert tmp1 select t.* , lev from test t join tmp2 a on t.id=a.pid;
    while exists(select 1 from tmp2 )
do
truncate tmp2;
set lev=lev+1;
insert tmp2 select t.id from test t join tmp1 a on t.id=a.parentid and a.levv=lev-1;
insert tmp1 select t.*,lev from test t join tmp2 a on t.id=a.pid;
end while ;
select id,name,parentid from tmp1;
end;
$$
 
delimiter ;
 
 call usp_ser('c877b7ea-4ed3-f472-9527-53e1618cb1dc');
+--------------------------------------+----------+--------------------------------------+
| id                  | name   | parentid               |
+--------------------------------------+----------+--------------------------------------+
| 13ed38f1-3c24-dd81-492f-673686dff0f3 | 大學教師 | 37e2ea0a-1c31-3412-455a-5e60b8395f7d |
| 37e2ea0a-1c31-3412-455a-5e60b8395f7d | 教師   | NULL                 |
+--------------------------------------+----------+--------------------------------------+
 
 call usp_ser('13ed38f1-3c24-dd81-492f-673686dff0f3');
+--------------------------------------+------+----------+
| id                  | name | parentid |
+--------------------------------------+------+----------+
| 37e2ea0a-1c31-3412-455a-5e60b8395f7d | 教師 | NULL   |
+--------------------------------------+------+----------+
 
 call usp_ser('37e2ea0a-1c31-3412-455a-5e60b8395f7d');
 
Empty set (0.02 sec)

上面的方法因為由于MySQL中不允許在同一語句中對臨時表多次引用,所以用2次臨時表
下面給個一次性用普通表完成的 查詢子節點的遞歸查詢

核心代碼

drop table if exists test;
create table test(
id INT,
parentid INT
);
insert test select
1, 0 UNION ALL SELECT 
2, 1 UNION ALL SELECT 
3, 1 UNION ALL SELECT 
4, 0 UNION ALL SELECT 
5, 2 UNION ALL SELECT 
6, 5 UNION ALL SELECT 
7, 3 ;
Go
 
delimiter $$
 
create procedure usp_ser(in idd varchar(100))
begin
declare lev int;
set lev=1;
drop table if exists tmp1;
CREATE TABLE tmp1(id INT,parentid INT ,levv INT,ppath VARCHAR(1000));

INSERT tmp1 SELECT *,lev,id FROM test WHERE parentid=idd;

 while row_count()>0
do

set lev=lev+1;
insert tmp1 select t.*,lev,concat(a.ppath,t.id) from test t join tmp1 a on t.parentid=a.id AND levv=LEV-1;
 
end while ;
SELECT * FROM tmp1;
 
end;
$$
 
delimiter ;
 
 call usp_ser(0);
 
/*
+------+----------+------+-------+
| id  | parentid | levv | ppath |
+------+----------+------+-------+
|  1 |    0 |  1 | 1   |
|  4 |    0 |  1 | 4   |
|  2 |    1 |  2 | 12  |
|  3 |    1 |  2 | 13  |
|  5 |    2 |  3 | 125  |
|  7 |    3 |  3 | 137  |
|  6 |    5 |  4 | 1256 |
+------+----------+------+-------+*/

您可能感興趣的文章:
  • MySQL遞歸查詢樹狀表的子節點、父節點具體實現
  • SQL如何實現MYSQL的遞歸查詢
  • php+mysql不用遞歸實現的無限級分類實例(非遞歸)
  • 使用遞歸刪除樹形結構的所有子節點(java和mysql實現)
  • 使用函數遞歸實現基于php和MySQL的動態樹型菜單
  • 利用java+mysql遞歸實現拼接樹形JSON列表的方法示例
  • PHP遞歸寫入MySQL實現無限級分類數據操作示例
  • Mysql樹形遞歸查詢的實現方法

標簽:朔州 AXB 三明 宿州 林芝 內江 咸寧 汕頭

巨人網絡通訊聲明:本文標題《MySQL之遞歸小問題》,本文關鍵詞  MySQL,之,遞歸,小,問題,MySQL,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL之遞歸小問題》相關的同類信息!
  • 本頁收集關于MySQL之遞歸小問題的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 宣城市| 贡山| 泽库县| 卢湾区| 罗田县| 崇左市| 呼伦贝尔市| 宜君县| 板桥市| 南昌县| 汉阴县| 岱山县| 库车县| 开平市| 阳原县| 林州市| 建阳市| 嵊泗县| 宜君县| 全椒县| 长沙县| 乌恰县| 淮安市| 大冶市| 田林县| 长宁县| 普格县| 固原市| 清涧县| 馆陶县| 唐海县| 赞皇县| 华容县| 冀州市| 咸阳市| 高碑店市| 麟游县| 高台县| 江山市| 桐乡市| 大英县|