Mysql 遞歸查詢子類Id的所有父類Id

文章目錄

  • 問題描述
    • 先看結果
    • 表結構展示
    • 實現遞歸查詢集合
    • 查詢結果
    • 修復數據

問題描述

最近開發過程中遇到一個問題,每次添加代理關系都要去遞歸查詢一下它在不在這個代理關系樹上.很麻煩也很浪費資源.想著把代理關系的父類全部存起來

先看結果

在這里插入圖片描述

表結構展示

表名(t_agent_user_relation)
字段名字段類型描述
current_user_idint當前用戶id
superior_user_idint代理用戶id
parent_idsvarchar父類Id集合以逗號隔開
parent_idint父類ID
idint主鍵

實現遞歸查詢集合

因為沒有對應函數,需要自行編寫遞歸查詢函數

createdefiner = root@`%` function getParentIds(child_id int) returns varchar(255)
BEGINDECLARE parent_id varchar(255) default '';DECLARE parent_ids VARCHAR(1500) default '';DECLARE count int;DECLARE sum int default 0;-- 獲取當前子類的父類IDSELECT superior_user_id INTO parent_id FROM t_agent_user_relation WHERE current_user_id = child_id;-- 遞歸查詢所有父類IDWHILE parent_id is not null && sum < 3DOSET parent_ids = CONCAT_WS(',', parent_ids, parent_id);SELECT count(1) into count FROM t_agent_user_relation WHERE current_user_id = parent_id;if count = 0 thenset parent_id = null;elseSELECT superior_user_id INTO parent_id FROM t_agent_user_relation WHERE current_user_id = parent_id;end if;-- 防止出現死循環if parent_id is not null && find_in_set(parent_id, parent_ids) > 0thenset sum = sum + 1;elseset sum = sum;end if;END WHILE;RETURN parent_ids;
END;

如果出現以下錯誤
[HY000][1418] This function has none of DETERMINISTIC, NO SQL, or READS SQL

執行set global log_bin_trust_function_creators = 1; 錯誤原因我就不在這里分析了,有興趣的自己查詢一下

查詢結果

select  current_user_id,superior_user_id,getParentIds(current_user_id) from t_agent_user_relation

在這里插入圖片描述

修復數據

update t_agent_user_relation set    parent_ids=  getParentIds(current_user_id)  where parent_ids is null

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/161695.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/161695.shtml
英文地址,請注明出處:http://en.pswp.cn/news/161695.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【nlp】3.1 Transformer背景介紹及架構

Transformer背景介紹 1 Transformer的誕生2 Transformer的優勢3 Transformer的市場4 Transformer架構4.1 Transformer模型的作用4.2 Transformer總體架構圖4.2.1 輸入部分4.2.2 輸出部分包含4.2.3 編碼器部分4.2.4 解碼器部分1 Transformer的誕生 2018年10月,Google發出一篇論…

Opengl 紋理(知識點)

紋理&#xff08;知識點&#xff09; 以下是紋理用到的知識點&#xff0c;至于具體流程操作請參考&#xff1a; https://learnopengl.com/Getting-started/Textures 紋理環繞 紋理環繞&#xff08;Texture Wrapping&#xff09;的作用是定義在紋理坐標超出標準范圍時系統如何…

Android 10.0 mtp模式下連接PC后只顯示指定文件夾功能實現

1. 前言 在android10.0的系統定制化開發中,對于usb作為otg連接電腦時,在mtp模式下會作為一個存儲器在電腦端顯示,作為電腦的 一個盤符,來顯示設備的內部存儲的文件,所以說如果要對設備內部的資料做保密處理的時候,需要在mtp模式下不顯示某些 文件夾,接下來就分析下相關…

【算法萌新闖力扣】:兩句話中的不常見單詞

力扣熱題&#xff1a;兩句話中的不常見單詞 開篇 今天是備戰藍橋杯的第19天&#xff0c;今天到目前刷了4道力扣算法題。其中&#xff0c;這道題是對我來說收獲最大的一道&#xff0c;讓我更熟練地掌握了一些算法題中方法&#xff0c;于是來與大家分享一下。 題目鏈接: 884.兩…

服務器中了elbie勒索病毒解決辦法,elbie勒索病毒解密數據恢復

科技技術的不斷發展&#xff0c;為企業的生產運營提供了極大便利&#xff0c;但網絡安全威脅也不斷增加&#xff0c;近期云天數據恢復中心陸續接到很多企業的求助&#xff0c;企業的服務器中了elbie勒索病毒&#xff0c;導致系統癱瘓&#xff0c;所有業務無法正常開展&#xff…

鏈表OJ--下

文章目錄 前言一、鏈表分割二、環形鏈表I三、環形鏈表II四、鏈表的回文結構五、隨機鏈表的復制 前言 一、鏈表分割 牛客網CM11&#xff1a;鏈表分割- - -點擊此處傳送 題解&#xff1a; 思路圖&#xff1a; 代碼&#xff1a; 二、環形鏈表I 力扣141&#xff1a;環形鏈表…

使用SpringBoot集成MyBatis對管理員的查詢操作

增刪改查中的查詢操作&#xff0c;對所有的普通管理員進行查詢操作。 效果展示&#xff1a; 不僅可以在打開頁面時進行對管理員的自動查詢操作&#xff0c;還可以在輸入框進行查詢。 首先是前端向后端發送POST請求&#xff0c;后端接收到請求&#xff0c;如果是有參數傳到后端…

【uni-app】uniapp中彈出輸入框的示例

uni.showModal({title: 請輸入企業名稱,content: ,editable: true, //是否顯示輸入框placeholderText: 請輸入企業名稱, //輸入框提示內容confirmText: 確認,cancelText: 取消,success: (res) > {if (res.confirm) {this.checkDesc.name res.content;// console.log(輸入的…

內部網關協議_路由信息協議RIP_開放路徑優先OSPF協議_基本知識

目錄: 因特網路由選擇協議概述 路由信息協議RIP 開放路徑優先OSPF協議 因特網路由選擇協議概述 一.路由選擇分類 靜態路由選擇和動態路由選擇 靜態路由選擇: 采用人工配置的方式給路由器添加網絡路由、默認路由和特定主機路由等路由條目。靜態路由選擇簡單、開銷小&#…

移動端的自動化基于類實現啟動一次應用跑全部用例

1.unittest框架 class TestStringMethods(unittest.TestCase): def setUp(self) -> None: # 每一條測試用例開始前執行 print("setup") def tearDown(self) -> None: # 每一條測試用例結束后執行 print("teardown") …

八、ffmpeg錄制視頻為yuv文件

前言 測試環境&#xff1a; ffmpeg的4.3.2自行編譯版本windows環境qt5.12 圖片的一些重要知識&#xff1a; RGB圖片 位深度&#xff1a;每一個像素都會使用n個二進制位來存儲顏色信息。每一個像素的顏色都是由紅&#xff08;Red&#xff09;、綠&#xff08;Green&#xff0…

【python】python旅游網數據抓取分析(源碼+論文)【獨一無二】

&#x1f449;博__主&#x1f448;&#xff1a;米碼收割機 &#x1f449;技__能&#x1f448;&#xff1a;C/Python語言 &#x1f449;公眾號&#x1f448;&#xff1a;測試開發自動化【獲取源碼商業合作】 &#x1f449;榮__譽&#x1f448;&#xff1a;阿里云博客專家博主、5…

C語言——結構體的應用

歸納編程學習的感悟&#xff0c; 記錄奮斗路上的點滴&#xff0c; 希望能幫到一樣刻苦的你&#xff01; 如有不足歡迎指正&#xff01; 共同學習交流&#xff01; &#x1f30e;歡迎各位→點贊 &#x1f44d; 收藏? 留言?&#x1f4dd; 路還在繼續&#xff0c;夢還在期…

webGL技術開發的軟件類型

WebGL 是一種在瀏覽器中渲染 2D 和 3D 圖形的 JavaScript API。通過 WebGL&#xff0c;你可以創建各種類型的軟件項目&#xff0c;特別是那些需要強大圖形渲染能力的項目。以下是一些你可以使用 WebGL 實現的軟件項目類型&#xff0c;希望對大家有所幫助。北京木奇移動技術有限…

老生常談之 JavaScript 中 0.1 + 0.2 != 0.3 的原因

先來一個模棱兩可的說法&#xff1a;因為精度丟失、存儲溢出的問題 先復習一下二進制的轉換方法&#xff1a; 整數&#xff1a;除以基數&#xff0c;取余&#xff0c;自底向上小數&#xff1a;乘以基數&#xff0c;取整&#xff0c;自頂向下 接著&#xff0c;復習一下雙精度…

Linux使用操作

各類小技巧 ctrlc強制停止 ctrld退出賬戶的登錄 或者退出某些特定程序的專屬頁面 history 查看歷史命令 !命令前綴&#xff0c;自動執行上一次匹配前綴的命令 ctrlr 輸入內容去匹配歷史命令 光標移動快捷鍵 ctrla&#xff0c;跳到命令開頭 ctrle&#xff0c;跳到命令結尾…

【C語言_題庫】輸入4個整數,要求按照從小到大的順序輸出

題目 輸入4個整數 要求按照從小到大的順序輸出 書上的學習輔導答案 // 主要部分 int main(){int t,a,b,c,d;printf("請輸入四個數:");scanf("%d,%d,%d,%d"

SkyWalking全景解析:從原理到實現的分布式追蹤之旅

&#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交給時間 &#x1f3e0; &#xff1a;小破站 SkyWalking全景解析&#xff1a;從原理到實現的分布式追蹤之旅 前言第一&#xff1a;SkyWalking簡介第二&#xff1a;實現原理概覽第三&#xff1a;主鍵與架構第四&#xff1…

【計算機基礎】通過插件plantuml,實現在VScode里面繪制狀態機

&#x1f4e2;&#xff1a;如果你也對機器人、人工智能感興趣&#xff0c;看來我們志同道合? &#x1f4e2;&#xff1a;不妨瀏覽一下我的博客主頁【https://blog.csdn.net/weixin_51244852】 &#x1f4e2;&#xff1a;文章若有幸對你有幫助&#xff0c;可點贊 &#x1f44d;…

數學與她的

文章目錄 定義域函數的定義域&#xff1a;一般地復合函數求解極值&#xff0c;單調性綜合考題&#xff1a; 定義域 函數的定義域&#xff1a; 求定義域的原則性問題&#xff08;通用&#xff09;分母不為0 偶次根式的被開方式為非負&#xff08; ≥ 0 &#xff09; 偶次根式的…