91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

教你如何使用MySQL8遞歸的方法

發布時間:2020-08-24 07:08:23 來源:腳本之家 閱讀:367 作者:殷天文 欄目:MySQL數據庫

之前寫過一篇 MySQL通過自定義函數的方式,遞歸查詢樹結構,從MySQL 8.0 開始終于支持了遞歸查詢的語法

CTE

首先了解一下什么是 CTE,全名 Common Table Expressions

WITH
 cte1 AS (SELECT a, b FROM table1),
 cte2 AS (SELECT c, d FROM table2)
SELECT b, d FROM cte1 JOIN cte2
WHERE cte1.a = cte2.c;

cte1, cte2 為我們定義的CTE,可以在當前查詢中引用

可以看出 CTE 就是一個臨時結果集,和派生表類似,二者的區別這里不細說,可以參考下MySQL開發文檔:https://dev.mysql.com/doc/refman/8.0/en/with.html#common-table-expressions-recursive-examples

遞歸查詢

先來看下遞歸查詢的語法

WITH RECURSIVE cte_name AS
(
  SELECT ...   -- return initial row set
  UNION ALL / UNION DISTINCT
  SELECT ...   -- return additional row sets
)
SELECT * FROM cte;
  • 定義一個CTE,這個CTE 最終的結果集就是我們想要的 ”遞歸得到的樹結構",RECURSIVE 代表當前 CTE 是遞歸的
  • 第一個SELECT 為 “初始結果集”
  • 第二個SELECT 為遞歸部分,利用 "初始結果集/上一次遞歸返回的結果集" 進行查詢得到 “新的結果集”
  • 直到遞歸部分結果集返回為null,查詢結束
  • 最終UNION ALL 會將上述步驟中的所有結果集合并(UNION DISTINCT 會進行去重),再通過 SELECT * FROM cte; 拿到所有的結果集

遞歸部分不能包括:

  • 聚合函數例如 SUM()
  • GROUP BY
  • ORDER BY
  • LIMIT
  • DISTINCT

上面的講解可能有點抽象,通過例子慢慢來理解

WITH RECURSIVE cte (n) AS -- 這里定義的n相當于結果集的列名,也可在下面查詢中定義
(
 SELECT 1
 UNION ALL
 SELECT n + 1 FROM cte WHERE n < 5
)
SELECT * FROM cte;


-- result
+------+
| n  |
+------+
|  1 |
|  2 |
|  3 |
|  4 |
|  5 |
+------+

  • 初始結果集為 n =1
  • 這時候看遞歸部分,第一次執行 CTE結果集即是 n =1,條件發現并不滿足 n < 5,返回 n + 1
  • 第二次執行遞歸部分,CTE結果集為 n = 2,遞歸... 直至條件不滿足
  • 最后合并結果集

EXAMPLE

最后來看一個樹結構的例子

CREATE TABLE `c_tree` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `cname` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
 `parent_id` int(11) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
mysql> select * from c_tree;
+----+---------+-----------+
| id | cname  | parent_id |
+----+---------+-----------+
| 1 | 1    |     0 |
| 2 | 2    |     0 |
| 3 | 3    |     0 |
| 4 | 1-1   |     1 |
| 5 | 1-2   |     1 |
| 6 | 2-1   |     2 |
| 7 | 2-2   |     2 |
| 8 | 3-1   |     3 |
| 9 | 3-1-1  |     8 |
| 10 | 3-1-2  |     8 |
| 11 | 3-1-1-1 |     9 |
| 12 | 3-2   |     3 |
+----+---------+-----------+
mysql> 
WITH RECURSIVE tree_cte as
(
  select * from c_tree where parent_id = 3
  UNION ALL
  select t.* from c_tree t inner join tree_cte tcte on t.parent_id = tcte.id
)
SELECT * FROM tree_cte;
+----+---------+-----------+
| id | cname  | parent_id |
+----+---------+-----------+
| 8 | 3-1   |     3 |
| 12 | 3-2   |     3 |
| 9 | 3-1-1  |     8 |
| 10 | 3-1-2  |     8 |
| 11 | 3-1-1-1 |     9 |
+----+---------+-----------+
  • 初始結果集R0 = select * from c_tree where parent_id = 3
  • 遞歸部分,第一次 R0 與 c_tree inner join 得到 R1
  • R1 再與 c_tree inner join 得到 R2
  • ...
  • 合并所有結果集 R0 + ... + Ri

更多信息

https://dev.mysql.com/doc/refman/8.0/en/with.html

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肃宁县| 凉城县| 吉水县| 墨竹工卡县| 固始县| 施秉县| 余干县| 华亭县| 嵩明县| 芦溪县| 贵德县| 德化县| 榆林市| 彰武县| 大邑县| 永吉县| 滨州市| 府谷县| 油尖旺区| 连云港市| 海丰县| 徐闻县| 浦县| 永川市| 古浪县| 镇沅| 通州区| 兴化市| 锡林浩特市| 项城市| 嘉善县| 海伦市| 达孜县| 巨野县| 休宁县| 同心县| 舟山市| 六盘水市| 江都市| 洛隆县| 汽车|