doubleyong
管理员
管理员
  • 最后登录2025-12-02
  • 发帖数1198
  • 最爱沙发
  • 喜欢达人
  • 原创写手
  • 社区居民
  • 忠实会员
阅读:8186回复:0

mysql 中的union 与 union all

楼主#
更多 发布于:2016-05-24 13:27
来源: http://www.cnblogs.com/zzwlovegfj/archive/2012/06/23/2559592.html
union:联合的意思,即把两次或多次查询结果合并起来。
要求:两次查询的列数必须一致

推荐:列的类型可以不一样(mysql 支持),但推荐查询的每一列,相对应的类型也一样(因其它的数据库,有要求必须类型相似的 可以来自多张表的数据:多次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使用,会被语法分析器优化分析时去除。
知识需要管理,知识需要分享
游客


返回顶部

公众号

公众号