日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

SQL Union 和 Union All 的区别以及二者的性能问题 - 使用Sqlite演示

發(fā)布時(shí)間:2025/4/14 数据库 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL Union 和 Union All 的区别以及二者的性能问题 - 使用Sqlite演示 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1?Union 和 Union All 的區(qū)別

Union:對(duì)兩個(gè)結(jié)果集進(jìn)行并集操作,不包括重復(fù)行,同時(shí)進(jìn)行默認(rèn)規(guī)則的排序;

Union All:對(duì)兩個(gè)結(jié)果集進(jìn)行并集操作,包括重復(fù)行,不進(jìn)行排序;

? ? 也就是說(shuō) Union All的結(jié)果中包含重復(fù)行;

下面用sqlite來(lái)操作一下;

? ? 看一下 Union All 多了重復(fù)行;這是查詢結(jié)果的區(qū)別;

全部的cmd操作如下;

Microsoft Windows [版本 6.1.7601]
Copyright (c) 2010 Microsoft Corporation. ?All rights reserved.

S:\>cd sqlite

S:\sqlite>sqlite3 test1.db
SQLite version 3.7.15.2 2013-01-09 11:53:05
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> create table t1(
? ?...> id int not null,
? ?...> name varchar(30) not null);
sqlite> create table t2(
? ?...> id int not null,
? ?...> name varchar(30) not null);
sqlite> Insert into t1 values (1,'姚羽');
sqlite> Insert into t1 values (2,'邊兵兵');
sqlite> Insert into t1 values (3,'袁磊');
sqlite>
sqlite> Insert into t2 values (1,'姚羽');
sqlite> Insert into t2 values (2,'柳春平');
sqlite> Insert into t2 values (3,'張永超');
sqlite> Insert into t2 values (4,'劉華健');
sqlite> select * from t1;
1|姚羽
2|邊兵兵
3|袁磊
sqlite> select * from t2;
1|姚羽
2|柳春平
3|張永超
4|劉華健
sqlite> select * from Table1 union select * from Table2;
Error: no such table: Table2
sqlite> select * from t1 union select * from t2;
1|姚羽
2|邊兵兵
2|柳春平
3|袁磊
3|張永超
4|劉華健
sqlite> select * from t1 union all select * from t2;
1|姚羽
2|邊兵兵
3|袁磊
1|姚羽
2|柳春平
3|張永超
4|劉華健
sqlite>

2 union 和 union all 性能上的區(qū)別

優(yōu)先使用UNION ALL,避免使用UNION;UNION 因?yàn)闀?huì)將各查詢子集的記錄做比較,故比起UNION ALL ,通常速度都會(huì)慢上許多。

因?yàn)閡nion all不排除重復(fù)行,直接進(jìn)行并操作,所以快。

一般來(lái)說(shuō),如果使用UNION ALL能滿足要求的話,則使用UNION ALL。

還有一種情況,如果業(yè)務(wù)上能夠確保不會(huì)出現(xiàn)重復(fù)記錄,也使用UNION ALL。

總結(jié)

以上是生活随笔為你收集整理的SQL Union 和 Union All 的区别以及二者的性能问题 - 使用Sqlite演示的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。