您的位置:首页 > 数据库 > MySQL

mysql之union

2016-06-03 16:41 459 查看
今天来写写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时表的条件是:链接的表的列数必须互相相同,同时相对的列属性也必须相同。而列名可以不同(结构相同)。

举例实用条件:有几个内容相类似的表,想要以某些条件做出在几个表上的共同查询和排序模块。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mysql union