欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql實現Oracle中的Start with...Connect by方式

 更新時間:2024年12月23日 08:59:01   作者:HNT_Wings  
文章總結:作者在遷移數據庫時,使用了Oracle的startwith進行樹的遞歸查詢,但遇到了一些問題,通過搜索和修改,作者成功地使用存儲過程和預處理語句來實現動態(tài)查詢,并解決了變量聲明和預處理語句的問題

Mysql Oracle中的Start with...Connect by

工作需要,遷移數據庫時發(fā)現使用了Oracle中的start with來進行樹的遞歸查詢,所以自己動手豐衣足食。

通過一番搜索后發(fā)現

大家的實現基本都是這樣的:

CREATE FUNCTION queryChildrenAreaInfo(areaId INT)
RETURNS VARCHAR(4000)
BEGIN
DECLARE sTemp VARCHAR(4000);
DECLARE sTempChd VARCHAR(4000);

SET sTemp='$';
SET sTempChd = CAST(areaId AS CHAR);

WHILE sTempChd IS NOT NULL DO
SET sTemp= CONCAT(sTemp,',',sTempChd);
SELECT GROUP_CONCAT(id) INTO sTempChd FROM t_areainfo WHERE FIND_IN_SET(parentId,sTempChd)>0;
END WHILE;
RETURN sTemp;

但是這樣的代碼沒法復用(而且我的navicat居然建立函數失敗,或者各種錯誤,所以我使用了存儲過程,效果一樣),所以我們使用set和execute來進行語句的拼接和執(zhí)行,

修改后

如下:

CREATE PROCEDURE getChildList
IN rootId DECIMAL(65),
IN tablesname VARCHAR(6000),
OUT sTemp VARCHAR(6000)
BEGIN
DECLARE sTempChd VARCHAR(4000);

SET sTemp='$';
SET sTempChd = CAST(rootId AS CHAR);

WHILE sTempChd IS NOT NULL DO
SET sTemp= CONCAT(sTemp,',',sTempChd);
set @sqlexe = concat("SELECT GROUP_CONCAT(id) INTO sTempChd FROM " , tablesname , " WHERE FIND_IN_SET(parentId,sTempChd)>0;")
prepare sqlexe from @sqlexe;
execute sqlexe;
END WHILE;
END;

這樣一來我們就可以將表名作為參數傳入,但是一番執(zhí)行后,你會發(fā)現,哦豁,它居然報了這樣一個錯:

1327 - Undeclared variable: sTempChd;

這個低級錯誤困擾了我半天,我不是聲明了sTempChd為declare嗎?

答案很簡單

預處理語句(也就是我們的prepare)中,只接受@聲明的參數。因為在存儲過程中,使用動態(tài)語句,預處理時,動態(tài)內容必須賦給一個會話變量,也就是@形式聲明的變量,而declare聲明的是存儲過程變量,具體的內容涉及到更深的知識,我暫時無法找到原因。

前文是自上而下的查詢,自下而上的查詢其實很簡單,只要替換一下參數和語句內容就可以了,

具體如下:

CREATE PROCEDURE `getParentList`( 
	IN rootId DECIMAL(65,0), 
	IN tablesname VARCHAR ( 500 ),
	OUT sTemp VARCHAR ( 6000 ) )
BEGIN
	DECLARE
		PARENTID DECIMAL(65);
	SET sTemp = '$';
	SET @sTempChd = cast(rootId as char);
	WHILE @sTempChd <> 0 DO
		SET sTemp = concat( sTemp, ',', @sTempChd );
		SET @sqlcmd = CONCAT("SELECT PARENTID into @sTempChd FROM " , tablesname , " WHERE CATEID = " , @sTempChd , ";");
		PREPARE stmt FROM @sqlcmd;
		EXECUTE stmt;
	END WHILE;
	DEALLOCATE PREPARE stmt;
END

別忘了,最后要執(zhí)行一下deallocate語句,釋放預處理sql,免得session的預處理語句過多,達到max_prepared_stmt_count的上限值。

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • MySQL Router實現MySQL的讀寫分離的方法

    MySQL Router實現MySQL的讀寫分離的方法

    MySQL Router是MySQL官方提供的一個輕量級MySQL中間件,用于取代以前老版本的SQL proxy。本文主要介紹了MySQL Router實現MySQL的讀寫分離的方法,感興趣的可以了解一下
    2021-05-05
  • MySQL?到Oracle?實時數據同步

    MySQL?到Oracle?實時數據同步

    這篇文章主要介紹了MySQL?到Oracle?實時數據同步,本次?MySQL?數據實時同步到?Oracle大概只花了幾分鐘就完成。使用的工具是Tapdata?Cloud?,這個工具是永久免費的,需要的朋友可以參考一下
    2022-01-01
  • 在 Windows 10 上安裝 解壓縮版 MySql(推薦)

    在 Windows 10 上安裝 解壓縮版 MySql(推薦)

    這篇文章主要介紹了在 Windows 10 上安裝 解壓縮版 MySql(推薦)的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12
  • mysql 字符串轉數組的實現示例

    mysql 字符串轉數組的實現示例

    有時候,我們需要將一個字符串拆分成一個數組,本文主要介紹了mysql 字符串轉數組的實現示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-01-01
  • 分析一條sql的性能的標準總結

    分析一條sql的性能的標準總結

    在本篇文章里小編給各位分享了關于分析一條sql的性能的相關知識點總結內容,有興趣的朋友們學習下。
    2019-07-07
  • Mysql中被鎖住的表查詢以及如何解鎖詳解

    Mysql中被鎖住的表查詢以及如何解鎖詳解

    這篇文章主要介紹了Mysql中被鎖住的表查詢以及如何解鎖的相關資料,這些方法可以幫助你釋放鎖并恢復表的正常使用,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2025-03-03
  • Linux如何添加mysql系統(tǒng)環(huán)境變量

    Linux如何添加mysql系統(tǒng)環(huán)境變量

    這篇文章主要介紹了Linux如何添加mysql系統(tǒng)環(huán)境變量問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • MySQL?中的?SQL_MODE?設置方法ANSI_QUOTES?選項解析與應用小結

    MySQL?中的?SQL_MODE?設置方法ANSI_QUOTES?選項解析與應用小結

    sql_mode是?MySQL?中的一個系統(tǒng)變量,用于控制?SQL?語句的解析和執(zhí)行方式,它由多個選項組成,每個選項都可以獨立設置,以滿足不同的應用場景需求,這篇文章主要介紹了MySQL?中的?SQL_MODE?設置:ANSI_QUOTES?選項解析與應用
    2024-12-12
  • MySQL如何更改數據庫數據存儲目錄詳解

    MySQL如何更改數據庫數據存儲目錄詳解

    這篇文章主要給大家介紹了關于MySQL如何更改數據庫數據存儲目錄的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • MySQL定位長事務(Identify Long Transactions)的實現

    MySQL定位長事務(Identify Long Transactions)的實現

    在MySQL的運行中,經常會遇到一些長事務,本文主要介紹了MySQL定位長事務,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-09-09

最新評論