欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL8.0的WITH查詢?cè)斍?/h1>
 更新時(shí)間:2021年08月27日 16:10:38   作者:janbar  
這篇文章主要介紹了MySQL的WITH查詢?cè)斍?,需要的下伙伴可以參考下?/div>

 關(guān)于MySQL8的WITH查詢學(xué)習(xí)

前言:

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

1、示例

官方第一個(gè)示例,可以看出該查詢語(yǔ)句創(chuàng)建了cte1,cte2,cte3,cte4這4個(gè)臨時(shí)表,后面的臨時(shí)表依賴前面的臨時(shí)表數(shù)據(jù)。
最后一行為最終查詢結(jié)果,實(shí)際ct4因?yàn)?code>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)

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

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

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

這個(gè)是將臨時(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 a<10
)
SELECT * FROM my_cte;
 
這個(gè)第一行沒(méi)有指定列名,然后列名由第一個(gè)查詢返回結(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 a<10
)
SELECT * FROM my_cte;

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

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 ]

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

3、練習(xí)

關(guān)于遞歸的練習(xí)主要用于表里面包含父節(jié)點(diǎn)id之類的,詳情可以參考下面的練習(xí)。
定義下面這樣的表,存儲(chǔ)每個(gè)區(qū)域(省、市、區(qū))的id,名字及上級(jí)區(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', '臺(tái)州市');
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í)表中只有一行數(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é)點(diǎn)數(shù)據(jù)放入臨時(shí)表
最終查詢出來(lái)的就是遞歸的結(jié)果。

到此這篇關(guān)于MySQL的WITH查詢?cè)斍榈奈恼戮徒榻B到這了,更多相關(guān)MySQL的WITH查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mysql數(shù)據(jù)庫(kù)之常用sql語(yǔ)句進(jìn)階與總結(jié)

    Mysql數(shù)據(jù)庫(kù)之常用sql語(yǔ)句進(jìn)階與總結(jié)

    這篇文章主要介紹了Mysql數(shù)據(jù)庫(kù)之常用sql語(yǔ)句,總結(jié)分析了MySQL數(shù)據(jù)庫(kù)常用的查詢、條件查詢、排序、連接查詢、子查詢等相關(guān)操作技巧,需要的朋友可以參考下
    2019-11-11
  • SQL語(yǔ)句中EXISTS的詳細(xì)用法大全

    SQL語(yǔ)句中EXISTS的詳細(xì)用法大全

    最近重新用到了exists關(guān)鍵字,對(duì)于其基本用法記錄一下,下面這篇文章主要給大家介紹了關(guān)于SQL語(yǔ)句中EXISTS的詳細(xì)用法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • MySQL如何添加外鍵

    MySQL如何添加外鍵

    MySQL是一種常用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),它支持外鍵的添加,本文主要介紹了MySQL如何添加外鍵,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • MySQL查詢優(yōu)化--調(diào)整內(nèi)部變量的詳解

    MySQL查詢優(yōu)化--調(diào)整內(nèi)部變量的詳解

    本篇文章是對(duì)MySQL查詢優(yōu)化中的調(diào)整內(nèi)部變量進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • win10下mysql5.7.21安裝詳細(xì)過(guò)程

    win10下mysql5.7.21安裝詳細(xì)過(guò)程

    這篇文章主要為大家詳細(xì)介紹了win10下mysql5.7.21安裝的詳細(xì)過(guò)程,以及安裝Mysql 5.7.21遇到的問(wèn)題,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • mysql 使用B+樹(shù)索引有哪些優(yōu)勢(shì)

    mysql 使用B+樹(shù)索引有哪些優(yōu)勢(shì)

    這篇文章主要介紹了mysql 使用B+樹(shù)索引有哪些優(yōu)勢(shì),幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2021-01-01
  • mysql報(bào)錯(cuò)Duplicate entry ‘xxx‘ for key ‘字段名‘的解決

    mysql報(bào)錯(cuò)Duplicate entry ‘xxx‘ for key&nbs

    有時(shí)候?qū)Ρ磉M(jìn)行操作,例如加唯一鍵,或者插入數(shù)據(jù),會(huì)報(bào)錯(cuò),本文就來(lái)介紹一下mysql報(bào)錯(cuò)Duplicate entry ‘xxx‘ for key ‘字段名‘的解決方法,感興趣的可以了解一下
    2023-10-10
  • MySQL判斷空值的三種方法

    MySQL判斷空值的三種方法

    在創(chuàng)建表時(shí),可以指定的列是否可以不包含值,如果在一個(gè)列不包含值,則其稱其為空值NULL,NULL一個(gè)特殊值,代表缺失的值或者不適用的情況,表示未知數(shù)據(jù),本文給大家介紹了MySQL判斷空值的三種方法,需要的朋友可以參考下
    2024-03-03
  • MySQL中出現(xiàn)亂碼問(wèn)題的終極解決寶典

    MySQL中出現(xiàn)亂碼問(wèn)題的終極解決寶典

    這篇文章主要介紹了MySQL中出現(xiàn)亂碼問(wèn)題的終極解決寶典,包括編碼轉(zhuǎn)換和SQL數(shù)據(jù)進(jìn)出等方面,無(wú)比給力,極力推薦這篇精華翻譯!需要的朋友可以參考下
    2015-08-08
  • JDBC-idea導(dǎo)入mysql連接java的jar包(mac)的方法

    JDBC-idea導(dǎo)入mysql連接java的jar包(mac)的方法

    這篇文章主要介紹了JDBC-idea導(dǎo)入mysql連接java的jar包(mac)的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09

最新評(píng)論