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

溫馨提示×

溫馨提示×

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

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

SQL中的union和union?all怎么使用

發布時間:2023-02-22 10:55:25 來源:億速云 閱讀:120 作者:iii 欄目:MySQL數據庫

這篇文章主要介紹了SQL中的union和union all怎么使用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇SQL中的union和union all怎么使用文章都會有所收獲,下面我們一起來看看吧。

概念

MySQL UNION 操作符用于連接兩個以上的 SELECT 語句的結果組合到一個結果集合中。多個 SELECT 語句會刪除重復的數據。

UNION 操作符選取不同的值,如果允許得到重復的值,可以使用 UNION ALL

基礎語法

-- union
SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

-- union all
SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;

注意:
UNION 內部的每個 SELECT 語句必須擁有相同數量的列

列也必須擁有相似的數據類型

每個 SELECT 語句中的列的順序必須相同

使用技巧

我們發現我們用 UNION 得到的結果都是必須是相同的,這就不得不提 inor 這兩個關鍵字了

-- in
select * from users 
where name in ('sbc', 'bhy');

-- or
select * from users
where name = 'sbc' or name = 'bhy';

select * from users
where name = 'sbc' or tel = '123456';

-- union
select * from users
where name = 'sbc'
union
select * from users
where name = 'bhy';

select * from users
where name = 'sbc'
union
select * from users
where tel = '123456';

通過在用戶表(users)這幾個select語句中我們比較一下

如果我們想要名字為 sbc 或者 bhy 的用戶我們可以用inorunion都可以實現

如果在較大的數據量下差距就會有明顯的差距,如果 name 字段存在索引,這幾種方法都是不分上下的;可是如果像 or 寫法的第二種情況,那數據庫都會去找兩個字段各自的索引嗎,答案不是的,數據庫只會尋找一個字段的索引,而另一個字段就需要全局查詢

這樣遇到較大的數據量就會耗費大量的時間,但是 union 方法的第二種方法就會引用兩次索引。

區別

  • union :對兩個結果集進行并集操作,不包括重復行,相當于distinct,同時進行默認規則的排序

  • union all:對兩個結果集進行并集操作,包括重復行,即所有的結果全部顯示,不管是不是重復;

tips
union all只是合并查詢結果,并不會進行去重和排序操作,在沒有去重的前提下,使用union all的執行效率要比union高

關于“SQL中的union和union all怎么使用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“SQL中的union和union all怎么使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

乌兰浩特市| 喜德县| 太原市| 普洱| 忻州市| 伊川县| 晋宁县| 嘉义市| 洛浦县| 沾益县| 临清市| 肇源县| 杭锦后旗| 七台河市| 中西区| 广东省| 阿尔山市| 成武县| 武邑县| 溧阳市| 雷山县| 玛沁县| 莎车县| 灵山县| 句容市| 台前县| 临泉县| 甘南县| 博乐市| 昭平县| 霞浦县| 尚志市| 织金县| 永新县| 耿马| 富宁县| 鸡东县| 华阴市| 道孚县| 海林市| 江门市|