欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

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

MySQL8.0的WITH查詢詳情

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

 關于MySQL8的WITH查詢學習

前言:

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

1、示例

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

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)

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

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)

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

這個是將臨時表列名指定在第一行
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;
 
這個第一行沒有指定列名,然后列名由第一個查詢返回結(jié)果確定
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;

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

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、練習

關于遞歸的練習主要用于表里面包含父節(jié)點id之類的,詳情可以參考下面的練習。
定義下面這樣的表,存儲每個區(qū)域(省、市、區(qū))的id,名字及上級區(qū)域的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', '上城區(qū)');
INSERT INTO tb VALUES('015', '004', '下城區(qū)');
INSERT INTO tb VALUES('016', '004', '拱墅區(qū)');
INSERT INTO tb VALUES('017', '004', '余杭區(qū)');
INSERT INTO tb VALUES('018', '011', '金東區(qū)');
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;

執(zhí)行結(jié)果:

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

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

您可能感興趣的文章:
  • 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

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

巨人網(wǎng)絡通訊聲明:本文標題《MySQL8.0的WITH查詢詳情》,本文關鍵詞  MySQL8.0,的,WITH,查詢,詳情,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL8.0的WITH查詢詳情》相關的同類信息!
  • 本頁收集關于MySQL8.0的WITH查詢詳情的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    成年人小视频在线观看| 中文字幕资源站| 欧美日韩一区二区电影| 国产精品国产三级国产普通话蜜臀 | 日本91福利区| 欧洲熟妇的性久久久久久| 91久久免费观看| 亚洲三级视频在线观看| 成人h精品动漫一区二区三区| 国产黄a三级三级| 欧美激情一区二区三区蜜桃视频| 黄色资源网久久资源365| 一区二区三区伦理片| www一区二区| 精品伊人久久久久7777人| 在线国产视频一区| 久久综合九色综合97婷婷| 麻豆91免费看| 免费视频91蜜桃| 国产亚洲精品免费| 国产999精品久久| 国产精品成人免费观看| 中文字幕日本乱码精品影院| 成人综合婷婷国产精品久久蜜臀| 国产大片免费看| 亚洲三级免费电影| 中文字幕18页| 欧美变态tickling挠脚心| 美女视频网站久久| 国产极品视频在线观看| 国产精品麻豆一区二区 | 精品福利二区三区| 国产精品一区2区| 男人操女人的视频网站| 亚洲综合精品久久| 中文字幕日韩三级片| 久久久久久久综合色一本| 国产69精品久久久久毛片| 91福利资源站| 日韩va亚洲va欧美va久久| 国产在线综合视频| 日韩美女久久久| 亚洲欧美日韩色| 久久久久久久网| 99精品视频在线观看| 777精品伊人久久久久大香线蕉| 奇米精品一区二区三区在线观看 | 久久久亚洲国产美女国产盗摄| 国产综合色视频| 欧美日韩黄色网| 亚洲精品少妇30p| 美女伦理水蜜桃4| 欧美主播一区二区三区| 婷婷综合久久一区二区三区| 久久精品国产亚洲av久| 日本一区二区三区在线不卡| 成人99免费视频| 欧美日韩国产首页在线观看| 免费看欧美女人艹b| 日韩视频在线观看免费视频| 亚洲色图欧美在线| 亚洲自拍偷拍精品| 国产婷婷色一区二区三区在线| caoporm超碰国产精品| 欧美日韩你懂得| 日韩和欧美一区二区三区| 中文字幕观看av| 亚洲电影第三页| 丁香激情五月少妇| 亚洲日本欧美天堂| 一本色道综合久久欧美日韩精品| 国产日产欧美一区二区视频| 91日韩一区二区三区| 日韩女优电影在线观看| 成人综合在线网站| 欧美精品99久久久**| 成人午夜电影久久影院| 欧美精品99久久久**| 国产成人免费视频一区| 欧美日韩国产大片| 国产精品一二三| 欧美精品少妇一区二区三区| 国产在线看一区| 欧美剧在线免费观看网站| 国产精品亚洲专一区二区三区| 91精彩视频在线观看| 韩国v欧美v日本v亚洲v| 欧美午夜电影在线播放| 国产一区二区三区精品视频| 欧美日韩一区在线| 国产精品一二三四区| 欧美一级黄色片| 波多野结衣在线aⅴ中文字幕不卡| 日韩精品一区二区三区中文不卡 | 欧美一区二区国产| 成人av网站在线| 欧美变态tickle挠乳网站| caoporn国产精品| 欧美激情一区二区三区全黄| 99久久人妻精品免费二区| 亚洲欧洲在线观看av| 日本高清www| 亚洲在线视频网站| www深夜成人a√在线| 美女视频免费一区| 色94色欧美sute亚洲13| 国产在线精品一区二区| 日韩欧美精品在线| 国产无套精品一区二区三区| 国产欧美精品一区aⅴ影院| 国产精品无码一区二区三| 亚洲精品视频一区| 无码人中文字幕| 免费在线观看日韩欧美| 欧美日韩在线精品一区二区三区激情| 美国一区二区三区在线播放| 欧美午夜精品电影| 97精品国产97久久久久久久久久久久| 国产喂奶挤奶一区二区三区| 91精品人妻一区二区| 亚洲一级二级三级在线免费观看| 91视频免费在线看| 国产成人精品影院| 久久免费国产精品| 亚洲 欧美 日韩在线| 亚洲一区二区三区国产| 色婷婷精品久久二区二区蜜臀av| 国产伦精品一区二区三区免费| 日韩欧美久久一区| 精品人妻一区二区三区日产乱码卜| 亚洲一区在线观看视频| 一本色道久久综合精品竹菊| 蜜桃视频在线观看一区二区| 欧美电视剧在线观看完整版| 午夜av免费看| 婷婷国产在线综合| 欧美日本乱大交xxxxx| 91欧美激情一区二区三区成人| 中文字幕亚洲精品在线观看| 看黄色录像一级片| 国产91高潮流白浆在线麻豆| 国产精品入口麻豆九色| 麻豆一区在线观看| 精品一区二区三区免费观看 | 国产福利一区在线| 久久久久久一二三区| www日韩在线| 成人永久免费视频| 一区二区中文视频| 在线观看免费一区| 久久aaaa片一区二区| 亚洲综合在线电影| 欧美久久久久久蜜桃| 超碰97人人干| 久久国产精品无码网站| 久久久久国产成人精品亚洲午夜| 神马久久久久久久久久久 | 欧美日韩国产综合一区二区| 亚洲乱妇老熟女爽到高潮的片| 亚洲一区二区三区在线| 在线视频你懂得一区二区三区| caoporn国产精品| 亚洲香肠在线观看| 91精品久久久久久久99蜜桃 | 欧美性色黄大片| 在线观看亚洲免费视频| 日本成人中文字幕在线视频| 日韩视频一区二区在线观看| 91国模少妇一区二区三区| 国模一区二区三区白浆| 国产精品美女一区二区在线观看| 色哟哟日韩精品| 一边摸一边做爽的视频17国产| 日韩av电影免费观看高清完整版| 久久综合久久综合亚洲| 五月天av网站| 激情综合激情五月| 蜜桃视频第一区免费观看| 久久久美女艺术照精彩视频福利播放| 日韩av手机在线免费观看| 91欧美一区二区| 免费欧美在线视频| 日本一区二区三区视频视频| 欧美日韩国产一级片| 国产免费无遮挡吸奶头视频| 国产成人免费视频网站| 亚洲国产一区二区视频| 精品人在线二区三区| 国精品无码一区二区三区| 波多野结衣在线一区| 男男gaygay亚洲| 国产精品国产三级国产普通话蜜臀| 欧美猛男超大videosgay| xxxxx在线观看| 99久久久精品| 蜜臀av性久久久久蜜臀aⅴ流畅| 中文字幕在线观看不卡| 6080午夜不卡| 九九热视频在线免费观看| 日本精品一二三区|