Mysql8.0遞歸查詢的簡(jiǎn)單用法示例
本文使用Mysql8.0的特新實(shí)現(xiàn)遞歸查詢,文中給出了詳細(xì)的實(shí)例代碼,下面話不多說了,來一起看看詳細(xì)的介紹吧
Mysql8.0遞歸查詢用法
表數(shù)據(jù)如下
+--------+----------+------------+
| cat_id | name | parent_cid |
+--------+----------+------------+
| 12 | 美妝 | 0 |
| 4 | 服裝 | 0 |
| 5 | 女裝 | 4 |
| 6 | 男裝 | 4 |
| 7 | 童裝 | 4 |
| 19 | 美容美體 | 12 |
| 18 | 彩妝 | 12 |
| 13 | 護(hù)膚 | 12 |
| 15 | 護(hù)膚套裝 | 13 |
| 40 | 防曬 | 13 |
| 39 | 卸妝 | 13 |
| 38 | 潤(rùn)唇膏 | 13 |
| 17 | 乳液面霜 | 13 |
| 16 | 面膜 | 13 |
| 14 | 化妝水 | 13 |
+--------+----------+------------+
1. 我們需要查詢出"服裝"分類下的所有子分類
with recursive type_cte as (
select * from t_category where cat_id = 4
union all
select t.* from t_category tinner join type_cte type_cte2 on t.parent_cid = type_cte2.cat_id
)
select
cat_id, name, parent_cid
from type_cte
+--------+------+------------+
| cat_id | name | parent_cid |
+--------+------+------------+
| 4 | 服裝 | 0 |
| 5 | 女裝 | 4 |
| 6 | 男裝 | 4 |
| 7 | 童裝 | 4 |
+--------+------+------------+
2. 查詢出所有“美妝”分類下的所有子分類,并且分類名稱帶上上級(jí)分類的名稱
with recursive type_cte as (
select cat_id,name,parent_cid from t_category where cat_id = 12
union all
select t.cat_id,concat(type_cte2.name,'>',t.name),t.parent_cid
from t_category t
inner join type_cte type_cte2 on t.parent_cid = type_cte2.cat_id
)
select
cat_id, name, parent_cid
from type_cte;
+--------+------------------------+------------+
| cat_id | name | parent_cid |
+--------+------------------------+------------+
| 12 | 美妝 | 0 |
| 13 | 美妝>護(hù)膚 | 12 |
| 18 | 美妝>彩妝 | 12 |
| 19 | 美妝>美容美體 | 12 |
| 14 | 美妝>護(hù)膚>化妝水 | 13 |
| 15 | 美妝>護(hù)膚>護(hù)膚套裝 | 13 |
| 16 | 美妝>護(hù)膚>面膜 | 13 |
| 17 | 美妝>護(hù)膚>乳液面霜 | 13 |
| 35 | 美妝>護(hù)膚>潔面 | 13 |
| 36 | 美妝>護(hù)膚>精華 | 13 |
| 37 | 美妝>護(hù)膚>眼霜 | 13 |
| 38 | 美妝>護(hù)膚>潤(rùn)唇膏 | 13 |
| 39 | 美妝>護(hù)膚>卸妝 | 13 |
| 40 | 美妝>護(hù)膚>防曬 | 13 |
+--------+------------------------+------------+
3. 查詢分類的所有父級(jí)分類
根據(jù)第二個(gè)問題的sql做一下調(diào)整即可
with recursive type_cte as (
select cat_id,name,parent_cid from t_category where cat_id = 40
union all
select t.cat_id,concat(type_cte2.name,'>',t.name),t.parent_cid
from t_category t
inner join type_cte type_cte2 on t.cat_id = type_cte2.parent_cid
)
select
cat_id, name, parent_cid
from type_cte;
+--------+----------------+------------+
| cat_id | name | parent_cid |
+--------+----------------+------------+
| 40 | 防曬 | 13 |
| 13 | 防曬>護(hù)膚 | 12 |
| 12 | 防曬>護(hù)膚>美妝 | 0 |
+--------+----------------+------------+
總結(jié)
到此這篇關(guān)于Mysql8.0遞歸查詢的文章就介紹到這了,更多相關(guān)Mysql8.0遞歸查詢內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信