mysql父子集查詢(根據(jù)父級查詢所有子集)
在表中一定要有id和pid,這樣才能使用該sql。
需求1:
根據(jù)pid查詢出其下的所有子集(比如,子集的子集的子集…)全部查詢出來。
- 首先,在表中按照父節(jié)點(parent_id)和id字段(id)的順序?qū)?shù)據(jù)進(jìn)行排序,并將排序后的結(jié)果存入 org_query 子查詢中。
- 然后,使用變量 @id 以遞歸方式檢索所有與指定節(jié)點相關(guān)的所有子節(jié)點。該變量初始化為 pid,并在 WHERE 子句和 SET 子句中用于確定與指定節(jié)點相關(guān)的行,直到找到樹的底部節(jié)點為止。關(guān)鍵的查詢部分是 CONCAT(@id, ‘,’, id) 函數(shù),它將每個查找到的子節(jié)點的id添加到 @id 變量中。其它一些細(xì)節(jié)如FIND_IN_SET 也保證了真正意義上的遞歸。
- 最后,使用 GROUP_CONCAT 函數(shù)將子節(jié)點ID綜合成一個用逗號分隔的字符串(all_sub_ids),并輸出結(jié)果表。
SELECT GROUP_CONCAT(id) AS all_sub_ids FROM ( SELECT * FROM ( SELECT id,parent_id FROM 表 ORDER BY parent_id, id ) org_query, (SELECT @id := 此處填寫需要查詢的PID) initialisation WHERE FIND_IN_SET(parent_id, @id) > 0 AND @id := CONCAT(@id, ',', id) ) sub_query;
這樣就把pid下所有的子集全部查詢出來,但是只在一列輸出,用,分割開來:
需求2:
根據(jù)pid查詢出其下的所有子集(比如,子集的子集的子集…)全部查詢出來,但是需要作為集合列表展示,一個id作為一條數(shù)據(jù):
這個sql使用時,需要區(qū)別mysql版本是5還是8!
- 首先,根據(jù)指定的節(jié)點ID,找到它在樹形結(jié)構(gòu)中的所有子節(jié)點。
- 然后,將所有子節(jié)點的 ID 按照層級關(guān)系連接成一個字符串。例如, ‘1,2,3,6,7,8’ 表示節(jié)點6, 7和 8 是節(jié)點3的子節(jié)點,節(jié)點1,2和3是根節(jié)點(第一層節(jié)點)。
- 接下來,使用 GROUP_CONCAT 函數(shù)和字符串替換操作確定每個子節(jié)點所在的層數(shù),并為每個節(jié)點分配一個行號,分配行號時需要使用 MySQL 的變量 (@rownum := @rownum + 1) 來生成唯一的行數(shù)。
- 最后,使用 SUBSTRING_INDEX 函數(shù)和整數(shù)參數(shù) rn,確定每個子節(jié)點的位置,截取出每個子節(jié)點的ID,并將它們添加到 id_list 中。
- 最終輸出的結(jié)果是一個帶有列名為"id_list"的表,該表包含由指定節(jié)點的所有子節(jié)點的 ID 組成的逗號分隔的列表。
5.7版本如下: SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(all_sub_ids, ',', rn), ',', -1) AS id_list FROM ( SELECT GROUP_CONCAT(id) AS all_sub_ids, ANY_VALUE(LENGTH(GROUP_CONCAT(id SEPARATOR ',')) - LENGTH(REPLACE(GROUP_CONCAT(id SEPARATOR ','), ',', '')) + 1) AS c, @rownum := @rownum + 1 AS rn FROM ( SELECT * FROM ( SELECT id,parent_id FROM 表 ORDER BY parent_id, id ) org_query, (SELECT @id := 此處填寫需要查詢的PID) initialisation WHERE FIND_IN_SET(parent_id, @id) > 0 AND @id := CONCAT(@id, ',', id) ) sub_query, (SELECT @rownum := 0) r GROUP BY rn ) ids;
8.0版本如下: SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(all_sub_ids, ',', rn), ',', -1) AS id_list, c FROM ( SELECT GROUP_CONCAT(id) AS all_sub_ids, LENGTH(GROUP_CONCAT(id SEPARATOR ',')) - LENGTH(REPLACE(GROUP_CONCAT(id SEPARATOR ','), ',', '')) + 1 AS c, @rownum := @rownum + 1 AS rn FROM ( SELECT * FROM ( SELECT id, parent_id FROM 表 ORDER BY parent_id, id ) org_query, (SELECT @id := 此處填寫需要查詢的PID) initialization WHERE FIND_IN_SET(parent_id, @id) > 0 AND @id := CONCAT(@id, ',', id) ) sub_query, (SELECT @rownum := 0) r GROUP BY rn, c ) ids;
簡化版:
上面的sql其實就是脫褲子放屁,哈哈哈哈
SELECT id FROM ( SELECT id,parent_id FROM process_bim_data ORDER BY parent_id, id ) org_query, (SELECT @id := 452) initialisation WHERE FIND_IN_SET(parent_id, @id) > 0 AND @id := CONCAT(@id, ',', id)
結(jié)果如下:
到此這篇關(guān)于mysql父子集查詢(根據(jù)父級查詢所有子集)的文章就介紹到這了,更多相關(guān)mysql父子集查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql存儲過程學(xué)習(xí)筆記--建立簡單的存儲過程
我們常用的操作數(shù)據(jù)庫語言SQL語句在執(zhí)行的時候需要要先編譯,然后執(zhí)行,而存儲過程(Stored Procedure)是一組為了完成特定功能的SQL語句集,經(jīng)編譯后存儲在數(shù)據(jù)庫中,用戶通過指定存儲過程的名字并給定參數(shù)(如果該存儲過程帶有參數(shù))來調(diào)用執(zhí)行它。2014-08-08Mysql?數(shù)據(jù)庫結(jié)構(gòu)及索引類型
這篇文章主要介紹了Mysql?數(shù)據(jù)庫結(jié)構(gòu)及索引類型,數(shù)據(jù)庫索引是?mysql?數(shù)據(jù)庫中重要的組成部分,是數(shù)據(jù)庫查詢數(shù)據(jù)速度提升的關(guān)鍵,本文將介紹數(shù)據(jù)庫索引的一些內(nèi)容,下文更多相關(guān)內(nèi)容,需要的小伙伴可以參考一下2022-05-05Mysql定時數(shù)據(jù)庫備份實現(xiàn)的保姆級教程
數(shù)據(jù)備份本身主要是為了預(yù)防一些意外,例如服務(wù)器或者個人電腦的硬件故障、人為的錯誤操作等情況,這篇文章主要給大家介紹了Mysql定時數(shù)據(jù)庫備份實現(xiàn)的保姆級教程,需要的朋友可以參考下2024-12-12Linux下MySQL數(shù)據(jù)庫的主從同步復(fù)制配置
這篇文章主要介紹了Linux下MySQL數(shù)據(jù)庫的主從同步配置,2017-11-11mysql判斷當(dāng)前時間是否在開始與結(jié)束時間之間且開始與結(jié)束時間允許為空
這篇文章主要介紹了mysql判斷當(dāng)前時間是否在開始與結(jié)束時間之間且開始與結(jié)束時間允許為空,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09mysql基礎(chǔ):mysqld_safe 啟動執(zhí)行流程詳解
本篇文章是對mysql基礎(chǔ)中的mysqld_safe啟動執(zhí)行流程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06