mysql之union
2015-07-18 11:46
621 查看
今天来写写union的用法及一些需要注意的。
union:联合的意思,即把两次或多次查询结果合并起来。
要求:两次查询的列数必须一致
推荐:列的类型可以不一样,但推荐查询的每一列,相对应的类型一样
可以来自多张表的数据:多次sql语句取出的列名可以不一致,此时以第一个sql语句的列名为准。
如果不同的语句中取出的行,有完全相同(这里表示的是每个列的值都相同),那么union会将相同的行合并,最终只保留一行。也可以这样理解,union会去掉重复的行。
如果不想去掉重复的行,可以使用union all。
如果子句中有order
by,limit,需用括号()包起来。推荐放到所有子句之后,即对最终合并的结果来排序或筛选。
如:(select * from a order by id) union (select * from b order
id);
在子句中,order by
需要配合limit使用才有意义。如果不配合limit使用,会被语法分析器优化分析时去除。
union:联合的意思,即把两次或多次查询结果合并起来。
要求:两次查询的列数必须一致
推荐:列的类型可以不一样,但推荐查询的每一列,相对应的类型一样
可以来自多张表的数据:多次sql语句取出的列名可以不一致,此时以第一个sql语句的列名为准。
如果不同的语句中取出的行,有完全相同(这里表示的是每个列的值都相同),那么union会将相同的行合并,最终只保留一行。也可以这样理解,union会去掉重复的行。
如果不想去掉重复的行,可以使用union all。
如果子句中有order
by,limit,需用括号()包起来。推荐放到所有子句之后,即对最终合并的结果来排序或筛选。
如:(select * from a order by id) union (select * from b order
id);
在子句中,order by
需要配合limit使用才有意义。如果不配合limit使用,会被语法分析器优化分析时去除。
相关文章推荐
- MySQL高效获取记录总数
- mysql如何创建一个定时事件
- mysql如何创建一个定时事件
- 如何更改MYSQL登入密码方法 修改ph…
- hive安装同时以mysql为元数据库
- window安装mysql方法图解
- MySQL 添加列、修改列、删除列的方法
- MySQL 错误
- MySql优化--数据库和表结构优化
- 为什么 mysql 里的 ibdata1 文件不断的增长?
- MySQL忘记root密码解决方法
- mysql 联表查询(内联、左联、右联、全联)的语法
- MySql优化--索引优化
- mac mysql 修改密码
- mysql数据库中命令行下常用命令的操作(增、删、改、查)和数据类型
- mysql 解压缩和赋权
- Mysql log_slave_updates 参数
- mysql下float类型使用一些误差详解
- mysql之触发器
- MySQL导入和导出数据库的方法