服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - mysql实现合并结果集并去除重复值

mysql实现合并结果集并去除重复值

2022-12-22 16:47shon wu Mysql

这篇文章主要介绍了mysql实现合并结果集并去除重复值方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

mysql 合并结果集并去除重复值

SELECT DISTINCT c.parent_id from (     SELECT parent_id  FROM tp_goods_category a join tp_goods g on a.id = g.cat_id GROUP BY parent_id UNION ALL  SELECT cat_id FROM tp_goods GROUP BY cat_id ) c;

先去除每个结果集中的重复值 以 group by 方式除去

SELECT parent_id  FROM tp_goods_category a join tp_goods g on a.id = g.cat_id GROUP BY parent_id 

SELECT cat_id FROM tp_goods GROUP BY cat_id 

mysql实现合并结果集并去除重复值

然后合并两个结果集 生成一个新的结果集 (或者可以成为新表)  在 使用DISTINCT  去除合并结果集中的重复值  注意  必须给  新结果集取一个别名  比如例子中的  c

mysql实现合并结果集并去除重复值

新的查询结果

mysql实现合并结果集并去除重复值

此语句为了删除分类表中   在goods表中不存在的  分类id  且 级别为第二级别  

mysql实现合并结果集并去除重复值

mysql 合并结果集(union,union all)

我需要在一个sql的执行结果中,显示两个或两个以上的where条件的结果(select 列的结构相同)。

考虑使用union,或union all 。

union 与 union all 执行结果不同

UNION 删除重复的记录再返回结果,即对整个结果集合使用了DISTINCT。结果中无重复数据。

UNION ALL 将各个结果合并后就返回,不删除重复记录。如果结果中有重复数据,则包含重复数据。

例如,

mysql> SELECT * FROM world.city where ID=2020 UNION SELECT * FROM world.city where ID=2020;
+------+-------+-------------+--------------+------------+
| ID   | Name  | CountryCode | District     | Population |
+------+-------+-------------+--------------+------------+
| 2020 | Tieli | CHN         | Heilongjiang |     265683 |
+------+-------+-------------+--------------+------------+
1 row in set (0.00 sec)

mysql> SELECT * FROM world.city where ID=2020 UNION ALL SELECT * FROM world.city where ID=2020;
+------+-------+-------------+--------------+------------+
| ID   | Name  | CountryCode | District     | Population |
+------+-------+-------------+--------------+------------+
| 2020 | Tieli | CHN         | Heilongjiang |     265683 |
| 2020 | Tieli | CHN         | Heilongjiang |     265683 |
+------+-------+-------------+--------------+------------+
2 rows in set (0.00 sec)

对UNION,UNION ALL的结果继续处理,需要加括号

比如要对合并后的结果集进行ORDER BY,LIMIT等操作需要对合并对象单个的SELECT语句加上括号。

并且把整体结果的条件ORDER BY,LIMIT等放到最后一个SELECT的括号后面。

例如,

(SELECT * FROM world.city
WHERE CountryCode = "JPN" AND Name LIKE "nishi%") 
UNION ALL 
(SELECT * FROM world.city
WHERE CountryCode = "CHN" AND Population >= 5000000) 
LIMIT 5;

mysql中,UNION,UNION ALL的性能/效率不同

从效率上说,UNION ALL 要比UNION快很多。

所以,如果可以确认合并的结果集中不包含重复的数据的话,或者需要的结果中即使包含重复也无所谓,那么就使用UNION ALL。

UNION

  • UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算。
  • UNION在运行时先取出各个表/各个select的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。

UNION ALL

  • UNION ALL只是简单的将结果合并后就返回。不涉及排序运算。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文地址:https://blog.csdn.net/ifyouwanttogo/article/details/80928816

延伸 · 阅读

精彩推荐
  • Mysqlmysql数据存放的位置在哪

    mysql数据存放的位置在哪

    在本篇文章里小编给大家分享的是关于mysql数据存放的位置及相关知识点内容,需要的朋友们可以参考下。 ...

    silencement3992020-07-08
  • MysqlMySQL巧用sum、case和when优化统计查询

    MySQL巧用sum、case和when优化统计查询

    这篇文章主要给大家介绍了关于MySQL巧用sum、case和when优化统计查询的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考...

    飞锅锅11472021-04-24
  • Mysql详解Mysql函数调用优化

    详解Mysql函数调用优化

    这篇文章主要介绍了Mysql 函数调用优化的相关资料,帮助大家更好的理解和学习使用MySQL数据库,感兴趣的朋友可以了解下...

    一只小码农正在路过4792021-05-05
  • MysqlMySQL查看和修改时区的方法

    MySQL查看和修改时区的方法

    这篇文章主要给大家介绍了关于MySQL查看和修改时区的方法,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的...

    CroWall22082020-11-28
  • MysqlMySQL 数据类型 大全

    MySQL 数据类型 大全

    mysql下的一些数据类型,后面附有类型的说明。 ...

    mysql教程网2582019-10-26
  • MysqlMySQL的Data_ADD函数与日期格式化函数说明

    MySQL的Data_ADD函数与日期格式化函数说明

    今天看到了MySQL的日期函数,里面很多有用的,这里只把两个参数不太好记的粘下来了。 ...

    mysql教程网4972019-11-08
  • MysqlMySQL数据库触发器从小白到精通

    MySQL数据库触发器从小白到精通

    触发器是SQLserver提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启...

    桃花键神4172022-03-09
  • MysqlMysql文件存储图文详解

    Mysql文件存储图文详解

    文件存储是我们日常开发中经常遇到的一个功能,下面这篇文章主要给大家介绍了关于Mysql文件存储的相关资料,需要的朋友可以参考下...

    大将黄猿11372021-08-09