mysql语法之union
UNION的语法结构:
SELECT ...
UNION [ ALL | DISTINCT ] SELECT ....
[ UNION [ ALL | DISTINCT ] SELECT .....]
UNION 用于将多个SELECT语句中的结果组合到单个结果集中。
1 第一个SELECT语句用的列名称用作返回结果的列名称

其中第一个select中查询的列名为user_name,第二个select中查询的列名为password,但显示的结果列名称只有user_name
在多个select语句中,对应的列应该具有相同的数据类型,如果相应的select猎德数据类型不匹配,则union结果中列的类型和长度会考虑所有的select语句检索的值
UNION DISTINCT 和 UNION ALL
UNION DISTINCT 组合俩个输入,并应用DISTINCT过滤重复的行,一般DISTINCT可以省略,因为UNION默认是删除结果中重复的行。UNION ALL不会删除重复的行,结果包括所有SELECT语句中所有的匹配行
SELECT * FROM T1 WHERE = 10 UNION ALL SELECT * FROM T1 WHERE a = 10;
查询出来的结果会有俩分相同的数据(这里就不做实际例子了)
UNION 中使用 ORDER BY 和 LIMIT
要对单个select语句应用ORDER BY 或 LIMIT ,请将子句放在括号括住的select语句中:
(select a from t1 where a = 10 order by a limit 10)
union
(select * from t2 where a = 11 order by a limit 10);
但要注意的是,ORDER BY 对于单个SELECT 语句的使用并不意味着在最终结果中进行排序,因为UNION默认情况下会生成一组无序的结果集。因此这里要使用ORDER BY 通常会结合LIMIT使用,来确定要取出的行的数量,如果只用了ORDER BY 没有配合使用LIMIT,那么ORDER BY 会被优化掉,因为它不会有任何效果
如果想整个结果集使用ORDER BY 或 LIMIT 进行排序或限制,请将各个SELECT语句括起来并把ORDER BY 或 LIMIT 放在最后:
(select a from t1 where a = 10 )
union
(select a from t2 where a = 11)
order by a limit 10;
但要注意上面的这种情况ORDER BY引用的列名不能包含表名(例如:table_name.col_name)
此外,如果要排序的列是别名,则该ORDER BY子句必须引用别名,而不是列名。以下第一个语句将起作用,但第二个语句将失败并显示 Unknown column 'a' in 'order clause'错误:
(SELECT a AS b FROM t) UNION (SELECT ...) ORDER BY b;
(SELECT a AS b FROM t) UNION (SELECT ...) ORDER BY a;
如果相在整个结果集中对每个SELECT的结果集排序,请在每个SELECT中选择一个附加列用以排序,并ORDER BY在最后添加一下内容:
(SELECT 1 AS sort_col, col1a, col1b, ... FROM t1)
UNION
(SELECT 2 AS sort_col,col2a, col2b, ... FROM t2) ORDER BY sort_col;
要在单个SELECT结果中另外维护排序顺序 ,请在ORDER BY子句中添加辅助列:
(SELECT 1 AS sort_col, col1a, col1b, ... FROM t1)
UNION
(SELECT 2, col2a, col2b, ... FROM t2) ORDER BY sort_col, col1a;
mysql语法之union的更多相关文章
- MySQL 常用语法 之 UNION与UNION ALL
下面讲一下mySql中的union和union all 的功能以及区别 A union B 是将表A的数据和表B的数据连接成一张表,前提是查询的两张表的列数一定要一样否则出错. A union all ...
- 【转】Mysql联合查询union和union all的使用介绍
Mysql的联合查询命令UNION和UNION ALL,总结了使用语法和注意事项,以及学习例子和项目例子,需要的朋友可以参考下 一.UNION和UNION ALL的作用和语法 UNION 用于合... ...
- mysql中的union操作(整理)
mysql中的union操作(整理) 一.总结 一句话总结: union两侧的字段数和字段类型要是一样的 union可以接多个 orderby和排序可以在最后的union组合之后 1.union简单实 ...
- MYSQL 语法大全自己总结的
mysql语法大全 --------数据链接---------------------数据库服务启动net start mysql --关闭服务net stop mysql --登录 -u,-p后面不 ...
- 学习mysql语法--基础篇(一)
前 言 mysql mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: 一.创建用户,创建数据库,给 ...
- 学习mysql语法--基础篇(二)
前 言 mysql mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: [SQL语句的组成] DML ...
- mysql语法之case when then与列转行
mysql语法中case when then与列转行的使用场景非常丰富. case语句类似java中条件分支语句的作用,可以类比java中的switch语句或者if语句来学习. 其语法如下: case ...
- mongo 与 传统mysql语法对比
MongoDB语法 MySql语法 db.test.find({'name':'foobar'})<==> select ...
- Mongodb与mysql语法比较
Mongodb与mysql语法比较 mongodb与mysql命令对比 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由 ...
随机推荐
- Fedora增加rc-local服务开机自启项
最近新装了一台Fedora 30系统,服务已经正常运行起来了,但是偶然发现当我的系统重启后,写在rc.local配置文件里的命令居然没生效,导致我系统重启,但是服务却没有正常运行,后来经过一番查阅 ...
- Excel-查找函数
1.VLOOKUP函数 该函数的语法规则如下: VLOOKUP(lookup_value,table_array,col_index_num,range_lookup) 多表关联查询---vlooku ...
- 实验1 C语言开发环境和数据类型、运算符、表达式
#include <stdio.h> int main () { int x; printf("输入一个整数:\n"); scanf("%d",&a ...
- Magisk —— 安卓新一代的第三方拓展,systemless模式
Magisk由宝岛台湾学生 topjohnwu 开发, XDA主贴:https://forum.xda-developers.com/apps/magisk 使用方法:第三方rec刷入zip 介绍: ...
- 解决VMware虚拟机中centos 7无法上网的问题
在WMware中安装centos 7后发现无法安装软件,开始以为是镜像服务器的问题,后来通过ping之后发现根本没办法连接到网络.由于很多设置都是默认的,并且虚拟机也是NAT模式,和电脑主机共享网络, ...
- 第02组 Alpha冲刺(6/6)
队名:無駄無駄 组长博客 作业博客 组员情况 张越洋 过去两天完成了哪些任务 准备"Alpha事后诸葛亮" 提交记录(全组共用) 接下来的计划 完善接口文档 调动组员积极性 还剩下 ...
- ROS第一次开网站跳转到公告页(任意地址跳转)方法
原文: http://bbs.routerclub.com/thread-74654-1-5.html ROS首页强开配置脚本: /ip firewall natadd action=dst-nat ...
- guava(二) Equivalence & Supplier
一.Equivalence 一种判定两个实例是否相等的策略 全路径: com.google.common.base 声明: @GwtCompatible public abstract class E ...
- 第四次实验报告:使用Packet Tracer理解RIP路由协议
目录 1 实验目的 2 实验内容 3. 实验报告 3.1 建立网络拓扑结构 3.2 配置参数 3.3 测试网络连通性 3.4 理解RIP路由表建立和更新 4. 理解RIP消息传得慢 5. 拓展 1 实 ...
- GC分析工具使用-gceacy分析堆栈
gceasy是一款在线的gc分析工具.试用一下分析jstack的日志 1.jstack -l 3539 > 3539.stack 2.打包成zip文件 3.上传https://gceasy.io ...