MYSQL使用Union将两张表的数据合并显示
使用UNION操作符
union:用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。
使用union操作符会将多张表中相同的数据取值一次,如果想将表1和表2中的值完整的显示出来,可以使用union all。
演示
小伙伴们自行创建一下表。
表1数据如下:

表2数据如下:

OK,表数据已经创建完成,一共五条数据,接下来我们去看一看union 和 union all 的使用。
使用union 看一下效果:
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 看一下效果:
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:相同的数据也会查询出来。
拓展:
为了区分哪张表中的数据,我们可以这样做
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

将两张表中的数据按时间排序
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数据合并显示内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
MySQL COUNT用法终极指南:(*)/(1)/(列名)哪个更高效
在日常开发中,几乎每个程序员都用过COUNT()函数,那么COUNT(*)、COUNT(1)、COUNT(column)有什么区别,哪个更快,下面小编就来和大家简单讲讲吧2025-08-08
如何解决MySQL安装遇到Start service红叉问题
在安装MySQL时,若遇到StartService步骤打红叉无法继续,可通过计算机管理以管理员身份运行服务,找到MySQL服务,更改为本地系统账户登录,解决安装问题,此方法为实际操作经验,可供参考,确保安装顺利完成2024-10-10
Navicat连接mysql报错2003(10060)的解决方法
本来好好的navicat连接数据库,突然间今天就打不开数据库了,下面这篇文章主要给大家介绍了关于Navicat连接mysql报错2003(10060)的解决方法,文中通过图文介绍的非常详细,需要的朋友可以参考下2023-04-04


最新评论