校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > MySQL中給定父行找到所有子行的解決方案

MySQL中給定父行找到所有子行的解決方案

熱門標簽:電話外呼系統改號 百應電話機器人優勢 曲靖移動外呼系統公司 啥是企業400電話辦理 南昌三維地圖標注 外呼系統打電話上限是多少 怎樣在地圖標注銷售區域 武漢網絡外呼系統服務商 地圖標注費用是多少

前言

備注:測試數據庫版本為MySQL 8.0

如需要scott用戶下建表及錄入數據語句,可參考:

scott建表及錄入數據sql腳本

一.需求

找到直接及簡介(即JONES下屬的下屬)為JONES工作的所有員工。

JONES下屬的員工列表如下所示:

±------±-----+
| ename | lvl |
±------±-----+
| JONES | 1 |
| SCOTT | 2 |
| FORD | 2 |
| ADAMS | 3 |
| SMITH | 3 |
±------±-----+

二.解決方案

能夠移到數的絕對頂部和底部是非常有用的。

對于這個解決方案,不需要特殊的格式設置。目標只是返回位于員工JONES下屬的所有員工,其中包括JONES自己。

這種類型的查詢展示了遞歸SQL拓展的有用性,如Oracle的connect by和SQL Server/DB 2/MySQL 8.0的with子句等。

with recursive emp2(ename,empno,lvl) as
(
SELECT ename,empno,1 lvl
 from emp 
 where ename = 'JONES'
union ALL
select e1.ename,e1.empno,lvl + 1
 from emp e1,emp2 e2
 where e1.mgr = e2.empno
)
select ename,lvl from emp2

測試記錄:

mysql> with recursive emp2(ename,empno,lvl) as
 -> (
 -> SELECT ename,empno,1 lvl
 -> from emp
 -> where ename = 'JONES'
 -> union ALL
 -> select e1.ename,e1.empno,lvl + 1
 -> from emp e1,emp2 e2
 -> where e1.mgr = e2.empno
 -> )
 -> select ename,lvl from emp2;
+-------+------+
| ename | lvl |
+-------+------+
| JONES | 1 |
| SCOTT | 2 |
| FORD | 2 |
| ADAMS | 3 |
| SMITH | 3 |
+-------+------+
5 rows in set (0.01 sec)

總結

到此這篇關于MySQL中給定父行找到所有子行的文章就介紹到這了,更多相關MySQL給定父行找所有子行內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:滄州 資陽 隨州 錦州 黑河 甘南 荊州 吉林

巨人網絡通訊聲明:本文標題《MySQL中給定父行找到所有子行的解決方案》,本文關鍵詞  MySQL,中,給定,父行,找到,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL中給定父行找到所有子行的解決方案》相關的同類信息!
  • 本頁收集關于MySQL中給定父行找到所有子行的解決方案的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 濮阳市| 鲁甸县| 颍上县| 云浮市| 新和县| 赤水市| 郧西县| 祥云县| 台湾省| 金川县| 嵩明县| 黎川县| 抚州市| 安多县| 博爱县| 乡宁县| 贡觉县| 大渡口区| 大丰市| 龙南县| 青海省| 扎兰屯市| 宝兴县| 原阳县| 惠东县| 沐川县| 庆云县| 华坪县| 田东县| 华蓥市| 陇川县| 滕州市| 台州市| 庄浪县| 三明市| 寻甸| 东平县| 连州市| 浦东新区| 乐至县| 浠水县|