MYSQL使用Union将两张表的数据合并显示

吾爱主题 阅读:146 2024-04-02 08:04:34 评论:0

使用union操作符

union:用于连接两个以上的 select 语句的结果组合到一个结果集合中。多个 select 语句会删除重复的数据。

使用union操作符会将多张表中相同的数据取值一次,如果想将表1和表2中的值完整的显示出来,可以使用union all。

演示

小伙伴们自行创建一下表。

表1数据如下: 

表2数据如下:

ok,表数据已经创建完成,一共五条数据,接下来我们去看一看union 和 union all 的使用。

使用union 看一下效果:

?
1 2 3 select t1.id id, t1. name name , t1.description description,t1.create_time time from table1 t1 union select t2.id id, t2. name name , t2.description description,t2.create_date time from table2 t2

我们可以看到使用union只会查出来四条数据。其中两条是相同的数据,则显示一条。

使用union all 看一下效果:

?
1 2 3 select t1.id id, t1. name name , t1.description description,t1.create_time time from table1 t1 union all select t2.id id, t2. name name , t2.description description,t2.create_date time from table2 t2

使用union all查出5条数据,ps:相同的数据也会查询出来。

拓展: 

为了区分哪张表中的数据,我们可以这样做

?
1 2 3 select t1.id id, t1. name name , t1.description description,t1.create_time time , 'table1' type from table1 t1 union all select t2.id id, t2. name name , t2.description description,t2.create_date time , 'table2' type  from table2 t2

将两张表中的数据按时间排序

?
1 2 3 select t3.* from ( select t1.id id, t1. name name , t1.description description,t1.create_time time , 'table1' type from table1 t1 union all select t2.id id, t2. name name , t2.description description,t2.create_date time , 'table2' type  from table2 t2) t3 order by t3. time desc

到此这篇关于mysql使用union将两张表的数据合并显示的文章就介绍到这了,更多相关mysql数据合并显示内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/zz0828zz/article/details/118576156

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容