union和union all 的区别

使用union关键字时,可以给出多条select 语句,并将它们的结果合成单个结果集。合并时两个表对应的列数和数据类型必须相同,每个select 语句之间使用union或union all 关键字分隔,union 执行的时候删除重复的记录,所有返回的行都是唯一,使用union all 关键字的作用是不删除重复行也不对结果进行自动排序。

例如:

mysql> select s_id,f_name from fruits where s_id=101 union select s_id,f_name from fruits where f_price<10;
+------+------------+
| s_id | f_name     |
+------+------------+
|  101 | apple      |
|  101 | blackberry |
|  101 | cherry     |
|  103 | apricot    |
|  106 | ahfjwj     |
|  103 | cococut    |
|  102 | grape      |
+------+------------+
7 rows in set (0.00 sec)

mysql> select s_id,f_name from fruits where s_id=101 union all select s_id,f_name from fruits where f_price<10;
+------+------------+
| s_id | f_name     |
+------+------------+
|  101 | apple      |
|  101 | blackberry |
|  101 | cherry     |
|  101 | apple      |
|  103 | apricot    |
|  106 | ahfjwj     |
|  101 | cherry     |
|  103 | cococut    |
|  102 | grape      |
+------+------------+
9 rows in set (0.00 sec)

每个select集是这样的

mysql> select s_id,f_name from fruits where s_id=101;
+------+------------+
| s_id | f_name     |
+------+------------+
|  101 | apple      |
|  101 | blackberry |
|  101 | cherry     |
+------+------------+
3 rows in set (0.00 sec)

mysql> select s_id,f_name from fruits where f_price<10
    -> ;
+------+---------+
| s_id | f_name  |
+------+---------+
|  101 | apple   |
|  103 | apricot |
|  106 | ahfjwj  |
|  101 | cherry  |
|  103 | cococut |
|  102 | grape   |
+------+---------+
6 rows in set (0.00 sec)

很明显 union all 没有去重,查询的结果还有重复的行,

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,767评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 3,837评论 0 11
  • SQL SELECT 语句 一、查询SQL SELECT 语法 (1)SELECT 列名称 FROM 表名称 (2...
    有钱且幸福阅读 5,704评论 0 33
  • 高三的生活来了,6点整的尿意也来了。 之前听说过高三的生活是做题、讲试卷、骂人、做题、讲试卷、骂人。。。 但现实是...
    Andy_0214阅读 144评论 0 0
  • (本文参加第28届柏林园征文,所有内容均为本人原创) 夏天过去,秋天过去,冬天又来了,在十一月白茫茫的大雾里,童真...
    Lister_阅读 473评论 0 1