婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL8.0的WITH查詢詳情

MySQL8.0的WITH查詢詳情

熱門標簽:話務外呼系統怎么樣 大眾點評星級酒店地圖標注 臨清電話機器人 高清地圖標注道路 拉卡拉外呼系統 云南電商智能外呼系統價格 智能外呼系統復位 外東北地圖標注 400電話可以辦理嗎

 關于MySQL8的WITH查詢學習

前言:

對于邏輯復雜的sql,with可以大大減少臨時表的數量,提升代碼的可讀性、可維護性
MySQL 8.0終于開始支持with語句了,對于復雜查詢,可以不用寫那么多的臨時表了。
可以查看官方文檔【點擊跳轉】

1、示例

官方第一個示例,可以看出該查詢語句創建了cte1,cte2,cte3,cte4這4個臨時表,后面的臨時表依賴前面的臨時表數據。
最后一行為最終查詢結果,實際ct4因為ct3結果包含3行數據,但是使用MAX,MIN得到一行結果。

WITH cte1(txt) AS (SELECT "This "),
     cte2(txt) AS (SELECT CONCAT(cte1.txt,"is a ") FROM cte1),
     cte3(txt) AS (SELECT "nice query" UNION
                   SELECT "query that rocks" UNION
                   SELECT "query"),
     cte4(txt) AS (SELECT concat(cte2.txt, cte3.txt) FROM cte2, cte3)
SELECT MAX(txt), MIN(txt) FROM cte4;
 
+----------------------------+----------------------+
| MAX(txt)                   | MIN(txt)             |
+----------------------------+----------------------+
| This is a query that rocks | This is a nice query |
+----------------------------+----------------------+
1 row in set (0,00 sec)

官方第二個示例是遞歸的用法,根據閱讀文檔,我分析下面查詢結果如下。
首先定義一個臨時表my_cte
分析SELECT 1 AS n,這個是決定臨時表的列名為n,值為1
然后SELECT 1+n FROM my_cte WHERE n10,這個是遞歸查詢n10,并將1+n作為結果填充臨時表
最終使用SELECT * FROM my_cte,查詢臨時表,因此查詢出的結果就顯而易見了

WITH RECURSIVE my_cte AS
(
  SELECT 1 AS n
  UNION ALL
  SELECT 1+n FROM my_cte WHERE n10
)
SELECT * FROM my_cte;
 
+------+
| n    |
+------+
|    1 |
|    2 |
|    3 |
|    4 |
|    5 |
|    6 |
|    7 |
|    8 |
|    9 |
|   10 |
+------+
10 rows in set (0,00 sec)

根據我的理解寫了如下2個不一樣的查詢,查詢結果都一樣。
值得注意的是臨時表里面的多個查詢列數量和類型必須一樣,不然會報錯。

這個是將臨時表列名指定在第一行
WITH RECURSIVE my_cte(a,b,c) AS
(
  SELECT 1,1,1
  UNION ALL
  SELECT 1+a,2+b,3+c FROM my_cte WHERE a10
)
SELECT * FROM my_cte;
 
這個第一行沒有指定列名,然后列名由第一個查詢返回結果確定
WITH RECURSIVE my_cte AS
(
  SELECT 1 AS a,1 AS b,1 AS c
  UNION ALL
  SELECT 1+a,2+b,3+c FROM my_cte WHERE a10
)
SELECT * FROM my_cte;

根據官方文檔,臨時表的語法模板如下,是可以有很多行的查詢共同組成。

WITH RECURSIVE cte_name [list of column names ] AS
(
  SELECT ...      -- specifies initial set
  UNION ALL
  SELECT ...      -- specifies initial set
  UNION ALL
  ...
  SELECT ...      -- specifies how to derive new rows
  UNION ALL
  SELECT ...      -- specifies how to derive new rows
  ...
)
[, any number of other CTE definitions ]

官方文檔還列出了,使用臨時表時可以增刪改查新表,具體可以去閱讀官方文檔。

3、練習

關于遞歸的練習主要用于表里面包含父節點id之類的,詳情可以參考下面的練習。
定義下面這樣的表,存儲每個區域(省、市、區)的id,名字及上級區域的pid

 
CREATE TABLE tb(id VARCHAR(3), pid VARCHAR(3), name VARCHAR(64));
 
INSERT INTO tb VALUES('002', 0, '浙江省');
INSERT INTO tb VALUES('001', 0, '廣東省');
INSERT INTO tb VALUES('003', '002', '衢州市');
INSERT INTO tb VALUES('004', '002', '杭州市');
INSERT INTO tb VALUES('005', '002', '湖州市');
INSERT INTO tb VALUES('006', '002', '嘉興市');
INSERT INTO tb VALUES('007', '002', '寧波市');
INSERT INTO tb VALUES('008', '002', '紹興市');
INSERT INTO tb VALUES('009', '002', '臺州市');
INSERT INTO tb VALUES('010', '002', '溫州市');
INSERT INTO tb VALUES('011', '002', '麗水市');
INSERT INTO tb VALUES('012', '002', '金華市');
INSERT INTO tb VALUES('013', '002', '舟山市');
INSERT INTO tb VALUES('014', '004', '上城區');
INSERT INTO tb VALUES('015', '004', '下城區');
INSERT INTO tb VALUES('016', '004', '拱墅區');
INSERT INTO tb VALUES('017', '004', '余杭區');
INSERT INTO tb VALUES('018', '011', '金東區');
INSERT INTO tb VALUES('019', '001', '廣州市');
INSERT INTO tb VALUES('020', '001', '深圳市');
 
WITH RECURSIVE cte AS (
 SELECT id,name FROM tb WHERE id='002'
 UNION ALL
 SELECT k.id, CONCAT(c.name,'->',k.name) AS name FROM tb k INNER JOIN cte c ON c.id = k.pid
) SELECT * FROM cte;

執行結果:

分析結果包含第一行SELECT id,name FROM tb WHERE id='002'的數據,此時表中只有一行數據
然后連表查詢SELECT k.id, CONCAT(c.name,'->',k.name) AS name FROM tb k INNER JOIN cte c ON c.id = k.pid,遞歸的將父節點數據放入臨時表
最終查詢出來的就是遞歸的結果。

到此這篇關于MySQL的WITH查詢詳情的文章就介紹到這了,更多相關MySQL的WITH查詢內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MySql8 WITH RECURSIVE遞歸查詢父子集的方法
  • mysql視圖之確保視圖的一致性(with check option)操作詳解
  • 安裝mysql出錯”A Windows service with the name MySQL already exists.“如何解決
  • MySQL 5.6 中TIMESTAMP with implicit DEFAULT value is deprecated錯誤
  • MySQL錯誤TIMESTAMP column with CURRENT_TIMESTAMP的解決方法
  • MySQL提示:The server quit without updating PID file問題的解決辦法
  • php SQL Injection with MySQL

標簽:三明 揚州 溫州 定西 山西 阿里 福州 無錫

巨人網絡通訊聲明:本文標題《MySQL8.0的WITH查詢詳情》,本文關鍵詞  MySQL8.0,的,WITH,查詢,詳情,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL8.0的WITH查詢詳情》相關的同類信息!
  • 本頁收集關于MySQL8.0的WITH查詢詳情的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    色偷偷一区二区三区| 国产精品理论在线观看| 日日摸夜夜添夜夜添精品视频| 中文字幕欧美日韩一区| caoporn国产精品| 亚洲欧美一区二区三区国产精品 | 韩国女主播一区二区三区| 中文字幕中文在线不卡住| 久久一区二区三区国产精品| 欧美视频一区二区三区四区| 日本久久电影网| 成人av在线播放网址| 国产高清精品在线| 国产精品资源在线| 国产精品久久久久久久久免费丝袜 | 日韩精品一区二区三区视频| 色噜噜狠狠成人中文综合| 日韩欧美国产综合一区 | 亚洲同性gay激情无套| 国产精品久久久久精k8 | 国产亚洲一二三区| 日本一区二区综合亚洲| 国产精品热久久久久夜色精品三区 | 国产成人精品免费网站| 婷婷丁香激情综合| 三级欧美在线一区| 久久se精品一区精品二区| 韩国午夜理伦三级不卡影院| 国产综合色在线| 成人永久看片免费视频天堂| av在线不卡免费看| 欧美色爱综合网| 欧美成人a∨高清免费观看| 久久免费国产精品| 亚洲色图欧洲色图婷婷| 亚洲电影视频在线| 美女免费视频一区二区| 国产一区不卡在线| 97国产精品videossex| 精品视频一区三区九区| 欧美va天堂va视频va在线| 久久女同性恋中文字幕| 亚洲乱码中文字幕| 久久99日本精品| 一本久道久久综合中文字幕 | 91丝袜美腿高跟国产极品老师| 色悠悠亚洲一区二区| 在线播放欧美女士性生活| 久久久久久久精| 一区二区三区小说| 黄网站免费久久| 欧美在线观看视频一区二区三区| 欧美一区二区三区四区久久| 国产精品嫩草久久久久| 美女任你摸久久| 在线一区二区三区做爰视频网站| 日韩三级视频在线观看| 亚洲图片欧美激情| 国产美女在线精品| 91精品国产综合久久久蜜臀粉嫩| 国产精品盗摄一区二区三区| 欧美一区二区人人喊爽| 国产亚洲人成网站| 亚洲成人av在线电影| 成人精品视频一区二区三区| 69成人精品免费视频| 亚洲欧美aⅴ...| 色综合一区二区| 26uuu欧美日本| 色综合天天性综合| 成人激情文学综合网| 在线播放视频一区| 亚洲天堂网中文字| 国产真实精品久久二三区| 欧美男女性生活在线直播观看| 国产精品嫩草影院av蜜臀| 久久精品免费观看| 欧美精品xxxxbbbb| 亚洲一级不卡视频| 色狠狠av一区二区三区| 欧美国产日本韩| 加勒比av一区二区| 欧美一区二区三区视频免费播放| 亚洲免费观看高清完整版在线观看| 国产精品一区一区三区| 日韩三级在线免费观看| 日韩电影一二三区| 91精品国产色综合久久ai换脸| 亚洲一区二区影院| 欧美日韩一区二区在线视频| 一区二区三区中文免费| 色哟哟国产精品免费观看| 国产欧美日韩激情| 成人av综合一区| 国产精品毛片大码女人| 国产 日韩 欧美大片| 国产精品网友自拍| 成人精品在线视频观看| 国产精品毛片a∨一区二区三区| 国产成人综合亚洲网站| 久久综合视频网| 国产成人精品免费看| 中文字幕不卡一区| 91亚洲精品一区二区乱码| 日韩伦理免费电影| 欧洲另类一二三四区| 亚洲一区二区在线播放相泽 | 一区二区三区在线影院| 色嗨嗨av一区二区三区| 午夜精品免费在线观看| 日韩欧美色综合网站| 国产精品综合二区| 国产精品麻豆久久久| 色先锋久久av资源部| 五月综合激情日本mⅴ| 欧美一区二区精美| 日韩欧美的一区二区| 国产精品18久久久久久vr| 一区在线观看免费| 欧美三级电影在线观看| 麻豆成人久久精品二区三区红| 国产三区在线成人av| 日本高清不卡视频| 国精产品一区一区三区mba桃花 | 国产欧美精品一区| 色综合久久天天| 久久99这里只有精品| 国产精品嫩草影院av蜜臀| 欧美人与禽zozo性伦| 日本黄色一区二区| 久久尤物电影视频在线观看| 国产一区二区三区在线观看精品 | 精品一二三四区| 国产精品国产成人国产三级| 欧美美女一区二区在线观看| 国产精品一区二区三区四区| 亚洲综合激情另类小说区| 欧美va在线播放| 欧美午夜电影一区| 99久久精品一区二区| 老司机午夜精品| 中文字幕综合网| 久久综合久久99| 亚洲sss视频在线视频| 国产成人鲁色资源国产91色综| 日韩视频中午一区| 色哟哟日韩精品| 高清国产一区二区| 奇米精品一区二区三区在线观看 | 亚洲免费成人av| 国产亚洲精久久久久久| 欧美日韩不卡在线| av不卡在线观看| 国产成人aaa| 老司机一区二区| 婷婷一区二区三区| 亚洲自拍偷拍欧美| 中文字幕中文字幕中文字幕亚洲无线| 亚洲成a人片在线观看中文| 国产精品女主播在线观看| 欧美成人猛片aaaaaaa| 69久久夜色精品国产69蝌蚪网| 色综合久久久久综合体| 成人黄色大片在线观看| 狠狠色狠狠色综合系列| 麻豆精品在线观看| 免费精品99久久国产综合精品| 午夜精品国产更新| 亚洲午夜激情网站| 亚洲一区二区成人在线观看| 中文字幕在线观看不卡视频| 国产拍揄自揄精品视频麻豆| ww亚洲ww在线观看国产| 欧美精品一区二区三区很污很色的 | 日韩欧美电影一二三| 在线观看区一区二| 在线影院国内精品| 欧美色综合网站| 欧美日韩综合不卡| 91麻豆精品国产91久久久资源速度 | 欧美在线观看18| 91网上在线视频| 色哟哟欧美精品| 欧美午夜寂寞影院| 欧美色图天堂网| 欧美蜜桃一区二区三区| 91精品综合久久久久久| 91精品在线免费观看| 日韩精品一区二区三区视频在线观看| 欧美一级片免费看| 久久九九久精品国产免费直播| 国产偷国产偷亚洲高清人白洁| 中文字幕乱码久久午夜不卡| 国产精品久久久久久一区二区三区 | 国产成人自拍在线| 国产高清无密码一区二区三区| 狠狠色丁香婷婷综合久久片| 国产成人在线观看免费网站| 成人av第一页| 欧美三级视频在线观看 |