mysql合并查询(多张表)union和unionall
mysql合并查询(多张表) union 和 union all
repeated怎么读简介
⼩序
:今天写⾸页动态业务的时候,⽤到了两张表,还需要分页查询,刚开始以为需要关联查询,后来发现关联的话不会放到⼀个实体,然后我就上⽹⽅法,然后发现了⼀个我没学过的sql语句union,union all,卧槽 还是得好好学习啊,前端我想学,mysql我想学,真的时间不够⽤啊,还得给学弟学妹拍趣味编程课看的视频,真的是烦啊!
如果我们需要将两个select语句的结果作为⼀个整体显⽰出来,我们就需要⽤到union或者union all关键字。union(或称为联合)的作⽤是将多个结果合并在⼀起显⽰出来。
UNION 操作符⽤于合并两个或多个 SELECT 语句的结果集。
请注意,UNION 内部的每个 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每个 SELECT 语句中的列的顺序必须相同。
区别:
Union:对两个结果集进⾏并集操作,不包括重复⾏,同时进⾏默认规则的排序; Union
All:对两个结果集进⾏并集操作,包括重复⾏,不进⾏排序;
Intersect:对两个结果集进⾏交集操作,不包括重复⾏,同时进⾏默认规则的排序;
Minus:对两个结果集进⾏差操作,不包括重复⾏,同时进⾏默认规则的排序。
语法演⽰
SQL UNION 语法
SELECT column_name(s) FROM table1
小森林是什么意思UNION
SELECT column_name(s) FROM table2;
注释:默认地,UNION 操作符选取不同的值。如果允许重复的值,请使⽤ UNION ALL。
SQL UNION ALL 语法
SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;
实战运⽤
演⽰数据库
在本教程中,我们将使⽤ RUNOOB 样本数据库。
下⾯是选⾃ “Websites” 表的数据:
mysql> SELECT * FROM Websites;
+----+--------------+---------------------------+-------+---------+
| id | name | url | alexa | country |
+----+--------------+---------------------------+-------+---------+
|1| Google | /|1| USA |
|2|淘宝| www.taobao/|13| CN |
|3|菜鸟教程| www.runoob/|4689| CN |
|4|微博| weibo/|20| CN |
|5| Facebook | www.facebook/|3| USA |
|7| stackoverflow | stackoverflow/|0| IND |
+----+---------------+---------------------------+-------+---------+
下⾯是 “apps” APP 的数据:
mysql> SELECT * FROM apps;
+----+------------+-------------------------+---------+
executives什么意思| id | app_name | url | country |
+----+------------+-------------------------+---------+
|1| QQ APP | im.qq/| CN |
|2|微博 APP | weibo/| CN |
|3|淘宝 APP | www.taobao/| CN |
+----+------------+-------------------------+---------+
3 rows in set (0.00 sec)
SQL UNION 实例
下⾯的 SQL 语句从 “Websites” 和 “apps” 表中选取所有不同的country(只有不同的值):
实例
SELECT country FROM Websites
UNION
SELECT country FROM apps
ORDER BY country;
执⾏以上 SQL 输出结果如下:
注释:UNION 不能⽤于列出两个表中所有的country。如果⼀些⽹站和APP来⾃同⼀个国家,每个国家只会列出⼀次。UNION 只会选取不同的值。请使⽤ UNION ALL 来选取重复的值!
SQL UNION ALL 实例
冒泡排序和简单选择排序的区别下⾯的 SQL 语句使⽤ UNION ALL 从 “Websites” 和 “apps” 表中选取所有的country(也有重复的值):
实例
SELECT country FROM Websites
UNION ALL
SELECT country FROM apps
ORDER BY country;
jvm进程和线程的区别执⾏以上 SQL 输出结果如下:
带有 WHERE 的 SQL UNION ALL
下⾯的 SQL 语句使⽤ UNION ALL 从 “Websites” 和 “apps” 表中选取所有的中国(CN)的数据(也有重复的值):实例
SELECT country, name FROM Websites
WHERE country='CN'
UNION ALL
SELECT country, app_name FROM apps
WHERE country='CN'
ORDER BY country;
执⾏以上 SQL 输出结果如下:
注释:UNION 结果集中的列名总是等于 UNION 中第⼀个 SELECT 语句中的列名。
注意要点
union和union all关键字需要注意:
union 和 union all都可以将多个结果集合并,⽽不仅仅是两个,你可以将多个结果集串起来。
使⽤union和union all必须保证各个select 集合的结果有相同个数的列,并且每个列的类型是⼀样的。但列名则不⼀定需要相同,oracle会将第⼀个结果的列名作为结果集的列名。
>mysql安装教程菜鸟课程
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论