六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

怎么讓MySQL中單句完成無限層次父子關(guān)系查詢

[摘要]在 SQL Server 中,使用 CTE 表達(dá)式很容易做到無限層次父子關(guān)系查詢;在不支持CTE表達(dá)式的版本中,借助函數(shù)遞歸也可以輕松實(shí)現(xiàn)。 在 MySQL 中,這個需求的實(shí)例稍顯復(fù)雜, MySQL...
在 SQL Server 中,使用 CTE 表達(dá)式很容易做到無限層次父子關(guān)系查詢;在不支持CTE表達(dá)式的版本中,借助函數(shù)遞歸也可以輕松實(shí)現(xiàn)。
在 MySQL 中,這個需求的實(shí)例稍顯復(fù)雜, MySQL 中沒有支持遞歸的查詢,沒有表值函數(shù),函數(shù)不支持遞歸,所以通常都是用循環(huán)實(shí)現(xiàn),顯得比較別扭。今天看到一個用單條語句實(shí)現(xiàn)的遞歸查詢,想法獨(dú)特,分享一下。

表結(jié)構(gòu)和數(shù)據(jù)

CREATE TABLE table1(id int, name varchar(10), parent_id int); 
INSERT table1 VALUES 
(1, ‘Home’,        0), 
(2, ‘About’,       1), 
(3, ‘Contact’,     1), 
(4, ‘Legal’,         2), 
(5, ‘Privacy’,      4), 
(6, ‘Products’,   1), 
(7, ‘Support’,     2);

查詢 id = 5 的所有父級

SELECT ID.level, DATA.* FROM( 

    SELECT 

        @id as _id, 

        (   SELECT @id := parent_id 

            FROM table1 

            WHERE id = @id 

        ) as _pid, 

        @l := @l+1 as level 

    FROM table1, 

        (SELECT @id := 5, @l := 0 ) b 

    WHERE @id > 0 
) ID, table1 DATA 
WHERE ID._id = DATA.id 
ORDER BY level;

根據(jù)這個父級查詢方法,很容易可以寫出查所有子級的,下面的查詢 id=2 的所有子級

SELECT ID.level, DATA.* FROM( 

    SELECT 

        @ids as _ids, 

        (   SELECT @ids := GROUP_CONCAT(id) 

            FROM table1 

            WHERE FIND_IN_SET(parent_id, @ids) 

        ) as cids, 

        @l := @l+1 as level 

    FROM table1, 

        (SELECT @ids :=’1’, @l := 0 ) b 

    WHERE @ids IS NOT NULL 
) id, table1 DATA 
WHERE FIND_IN_SET(DATA.id, ID._ids) 
ORDER BY level, id

本文講解了如何讓MySQL中單句實(shí)現(xiàn)無限層次父子關(guān)系查詢,更多相關(guān)內(nèi)容請關(guān)注php中文網(wǎng)。

相關(guān)推薦:

帶進(jìn)度的SQL Server FileStream如何存取

當(dāng)忘記 SQL Server 管理員密碼該如何處理

淺析MySQL中concat以及group_concat的使用

以上就是如何讓MySQL中單句實(shí)現(xiàn)無限層次父子關(guān)系查詢的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。




主站蜘蛛池模板: 天天干天天射天天 | 天堂网在线新版www 天堂网在线网站成人午夜网站 | 午夜黄色网址 | 天天看片天天干 | 日韩三级在线 | 日干夜操| 在线视频 亚洲 | 杨幂国产精品福利在线观看 | 欧美在线视频a | 日日摸夜夜欧美一区二区 | 色婷婷5月精品久久久久 | 日韩高清在线播放不卡 | 日韩毛片一级 | 一本伊人 | 亚州久久 | 午夜精品久久久久久影视riav | 日本一二三区在线视频 | 日本在线高清 | 五月激激激综合网色播胖胖 | 午夜视频免费在线播放 | 涩涩涩久久 | 伊人久久大香 | 伊人手机在线观看 | 亚洲福利一区二区精品秒拍 | 亚洲第五页 | 香蕉视频你懂的 | 天天草夜夜草 | 亚洲福利在线看 | 欧美在线观看一区二区三 | 亚洲精品福利你懂 | 午夜大片免费完整在线看 | 日本视频在线免费观看 | 日韩高清在线高清免费 | 日韩大片免费在线观看 | 青青草国产精品视频 | 色综合天天综合网国产成人网 | 色尼玛图 | 青青久在线视频免费观看 | 亚洲mm8成为人影院 亚洲h在线观看 | 欧美专区一区 | 亚洲狠狠成人综合网 |