亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL遞歸查詢樹狀表的子節(jié)點、父節(jié)點具體實現(xiàn)

 更新時間:2014年03月24日 16:58:42   作者:  
本程序?qū)懥藘蓚€sql存儲過程,子節(jié)點查詢算是照搬了,父節(jié)點查詢是逆思維弄的
簡介:mysql5.0.94版本,該版本以及較高級的版本(5.5、6等等)尚未支持循環(huán)遞歸查詢,和sqlserver、oracle相比,mysql難于在樹狀表中層層遍歷的子節(jié)點。本程序重點參考了下面的資料,寫了兩個sql存儲過程,子節(jié)點查詢算是照搬了,父節(jié)點查詢是逆思維弄的。

表結(jié)構(gòu)和表數(shù)據(jù)就不公示了,查詢的表user_role,主鍵是id,每條記錄有parentid字段(對應該記錄的父節(jié)點,當然,一個父節(jié)點自然會有一個以上的子節(jié)點嘛)
復制代碼 代碼如下:

CREATE FUNCTION `getChildList`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sChildList VARCHAR(1000);
DECLARE sChildTemp VARCHAR(1000);
SET sChildTemp =cast(rootId as CHAR);
WHILE sChildTemp is not null DO
IF (sChildList is not null) THEN
SET sChildList = concat(sChildList,',',sChildTemp);
ELSE
SET sChildList = concat(sChildTemp);
END IF;
SELECT group_concat(id) INTO sChildTemp FROM user_role where FIND_IN_SET(parentid,sChildTemp)>0;
END WHILE;
RETURN sChildList;
END;
/*獲取子節(jié)點*/
/*調(diào)用: 1、select getChildList(0) id; 2、select * 5From user_role where FIND_IN_SET(id, getChildList(2));*/


CREATE FUNCTION `getParentList`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sParentList varchar(1000);
DECLARE sParentTemp varchar(1000);
SET sParentTemp =cast(rootId as CHAR);
WHILE sParentTemp is not null DO
IF (sParentList is not null) THEN
SET sParentList = concat(sParentTemp,',',sParentList);
ELSE
SET sParentList = concat(sParentTemp);
END IF;
SELECT group_concat(parentid) INTO sParentTemp FROM user_role where FIND_IN_SET(id,sParentTemp)>0;
END WHILE;
RETURN sParentList;
END;
/*獲取父節(jié)點*/
/*調(diào)用: 1、select getParentList(6) id; 2、select * From user_role where FIND_IN_SET(id, getParentList(2));*/

弄完了,pm說不要弄存儲結(jié)構(gòu),在java里面多查幾次吧。。。存儲結(jié)構(gòu)有很多優(yōu)點,包括加快查詢速度、提高安全性等等,但是會加大數(shù)據(jù)庫負荷,很多文章建議結(jié)合使用,個人也覺得少用點會好些。

相關文章

  • 安裝和使用percona-toolkit來輔助操作MySQL的基本教程

    安裝和使用percona-toolkit來輔助操作MySQL的基本教程

    這篇文章主要介紹了安裝和使用percona-toolkit來輔助操作MySQL的基本教程,這里舉了五個最常見的命令用法,需要的朋友可以參考下
    2015-11-11
  • Mysql查詢優(yōu)化之IN子查詢優(yōu)化方法詳解

    Mysql查詢優(yōu)化之IN子查詢優(yōu)化方法詳解

    項目中有需要,使用MySQL的in子查詢,查詢符合in子查詢集合中條件的數(shù)據(jù),但是沒想到的是,MySQL的in子查詢會如此的慢,讓人無法接受,下面這篇文章主要給大家介紹了關于Mysql查詢優(yōu)化之IN子查詢優(yōu)化的相關資料,需要的朋友可以參考下
    2023-02-02
  • MySQL?條件查詢詳解

    MySQL?條件查詢詳解

    這篇文章主要介紹了MySQL條件查詢,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • MySQL 視圖的基礎操作(五)

    MySQL 視圖的基礎操作(五)

    這篇文章主要為大家詳細介紹了MySQL 視圖的基礎操作,告訴大家為什么使用視圖?如何創(chuàng)建視圖等問題,感興趣的小伙伴們可以參考一下
    2016-08-08
  • MySQL EXPLAIN語句的使用示例

    MySQL EXPLAIN語句的使用示例

    這篇文章主要介紹了MySQL EXPLAIN語句的使用示例,幫助大家更好的理解和學習使用MySQL,感興趣的朋友可以了解下
    2021-03-03
  • Mysql系統(tǒng)變量與狀態(tài)變量詳細介紹

    Mysql系統(tǒng)變量與狀態(tài)變量詳細介紹

    這篇文章主要介紹了Mysql系統(tǒng)變量與狀態(tài)變量詳細介紹,能夠在程序運行過程中影響Mysql程序行為的變量稱之為系統(tǒng)變量,想了解更多相關內(nèi)容的小伙伴可以參考下面文章內(nèi)容
    2022-09-09
  • Linux7操作系統(tǒng)中如何安裝MySQL5.6

    Linux7操作系統(tǒng)中如何安裝MySQL5.6

    這篇文章主要介紹了Linux7操作系統(tǒng)中如何安裝MySQL5.6問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Mysql表的操作方法詳細介紹

    Mysql表的操作方法詳細介紹

    這篇文章主要為大家詳細介紹了MySQL數(shù)據(jù)庫中表常用的一些操作方法,文中的示例代碼講解詳細, 對我們學習MySQL有一定幫助,需要的可以參考一下
    2022-09-09
  • mysql數(shù)據(jù)庫密碼忘記解決方法

    mysql數(shù)據(jù)庫密碼忘記解決方法

    大家好,本篇文章主要講的是mysql數(shù)據(jù)庫密碼忘記解決方法,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • MySQL如何恢復單庫或單表,以及可能遇到的坑

    MySQL如何恢復單庫或單表,以及可能遇到的坑

    這篇文章主要介紹了MySQL如何恢復單庫或單表,以及可能遇到的坑,幫助大家更好的備份數(shù)據(jù)庫,保護數(shù)據(jù)安全,感興趣的朋友可以了解下
    2020-09-09

最新評論