当前位置: 首页 > news >正文

UNION 和 UNION ALL

概述

UNION 和 UNION ALL 都是 SQL 中用于将多个 SELECT 语句的结果合并成一个结果集的操作符。它们都适用于需要将多个表或查询结果合并在一起的情况。但是它们的行为略有不同。

区别

UNION 和 UNION ALL 的区别在于,UNION 会将结果集合并成一个不含重复行的结果集,而 UNION ALL 则会保留所有的行,包括重复的行。

因为 UNION 需要去重,所以它需要对结果集进行排序和去重的操作,因此比 UNION ALL 操作要慢,并且消耗更多的系统资源。

使用方法

UNION

UNION 的基本语法如下:

  1. SELECT column1, column2, ... FROM table1

  2. UNION

  3. SELECT column1, column2, ... FROM table2;

这个语句会返回从 table1 和 table2 中检索的唯一行。注意,两个查询的列数必须相同,并且对应列的数据类型也必须相同。

如果希望在结果集中保留重复的行,需要使用 UNION ALL

UNION ALL

UNION ALL 的基本语法如下:

  1. SELECT column1, column2, ... FROM table1

  2. UNION ALL

  3. SELECT column1, column2, ... FROM table2;

这个语句会返回从 table1 和 table2 中检索的所有行,包括重复的行。

与 UNION 不同,UNION ALL 不会对结果集进行排序和去重的操作,因此比 UNION 更快,也更消耗较少的系统资源。

使用例子

以下是一些使用 UNION 和 UNION ALL 的例子。

示例1:使用 UNION 操作符

假设有两个表 employees 和 customers,它们的结构如下:

  1. employees

  2. | emp_id | first_name | last_name |

  3. |--------|------------|-----------|

  4. | 1 | John | Smith |

  5. | 2 | Jane | Doe |

  6. customers

  7. | cust_id | first_name | last_name |

  8. |---------|------------|-----------|

  9. | 1 | Mary | Jones |

  10. | 2 | Bill | Smith |

如果想要将这两个表中的所有人员的名字和姓氏组合成一个唯一的列表,可以使用 UNION 操作符:

 
  1. SELECT first_name, last_name FROM employees

  2. UNION

  3. SELECT first_name, last_name FROM customers;

这个语句会返回以下结果:

 
  1. | first_name | last_name |

  2. |------------|-----------|

  3. | John | Smith |

  4. | Jane | Doe |

  5. | Mary | Jones |

  6. | Bill | Smith |

请注意,UNION 操作符会去重结果集中的重复行,这使得查询更耗费资源和时间。如果不需要去重,请使用 UNION ALL 操作符,这样可以更快地获取结果集。

示例2:使用 UNION ALL 操作符

假设有两个表 sales 和 returns,它们的结构如下:

 
  1. sales

  2. | sale_id | product_name | sale_date | sale_amount |

  3. |---------|--------------|-----------|-------------|

  4. | 1 | Product A | 2022-01-01 | 1000 |

  5. | 2 | Product B | 2022-01-02 | 2000 |

  6. | 3 | Product C | 2022-01-03 | 3000 |

  7. returns

  8. | return_id | product_name | return_date | return_amount |

  9. |-----------|--------------|------------|---------------|

  10. | 1 | Product A | 2022-01-05 | 100 |

  11. | 2 | Product B | 2022-01-06 | 200 |

  12. | 3 | Product D | 2022-01-07 | 300 |

如果想要将这两个表中的所有销售和退货记录组合成一个列表,可以使用 UNION ALL 操作符:

 
  1. SELECT sale_id, product_name, sale_date, sale_amount FROM sales

  2. UNION ALL

  3. SELECT return_id, product_name, return_date, return_amount FROM returns;

这个语句会返回以下结果:

 
  1. | id | product_name | sale_date | amount |

  2. |-----|--------------|-----------|--------|

  3. | 1 | Product A | 2022-01-01 | 1000 |

  4. | 2 | Product B | 2022-01-02 | 2000 |

  5. | 3 | Product C | 2022-01-03 | 3000 |

  6. | 1 | Product A | 2022-01-05 | 100 |

  7. | 2 | Product B | 2022-01-06 | 200 |

  8. | 3 | Product D | 2022-01-07 | 300 |

请注意,这个结果集包含重复的行,因为 UNION ALL 不会去重。这使得 UNION ALL 更快,因为不需要排序和去重操作。

总结

在 SQL 查询中,UNION 和 UNION ALL 都是将多个查询结果集合并在一起的操作符。UNION 会去除结果集中的重复行,而 UNION ALL 则保留所有的行。在使用 UNION 和 UNION ALL 时需要注意,两个查询的列数必须相同,并且对应列的数据类型也必须相同。此外,如果需要去重,应该使用 UNION;如果不需要去重,应该使用 UNION ALL

http://www.lryc.cn/news/275819.html

相关文章:

  • NPS 内网穿透安装
  • 【C++学习笔记】C++多值返回写法
  • 读取带有梯度的张量的具体的值
  • 【分布式微服务专题】SpringSecurity快速入门
  • EasyRecovery2024永久免费版电脑数据恢复软件
  • iphone 苹果 IOS 越狱详细图文保姆级教程非常简单
  • 华为HarmonyOS 创建第一个鸿蒙应用 运行Hello World
  • [C#]Onnxruntime部署Chinese CLIP实现以文搜图以文找图功能
  • openssl ans1定义的实体
  • 【Linux Shell】4. 数组
  • 蓝牙运动耳机哪款好用?运动用什么耳机比较好?2024运动耳机推荐
  • XD6500S一款串口SiP模块 射频LoRa芯片 内置sx1262
  • 【华为OD机试真题2023CD卷 JAVAJS】测试用例执行计划
  • 猫长期吃猫粮好吗?主食冻干猫粮那种好吃又健康
  • 计算机毕业设计-----ssm停车位租赁系统
  • Git保姆级安装教程
  • 听GPT 讲Rust源代码--compiler(34)
  • 视频融合云平台/智慧监控平台EassyCVR告警警告出错是什么原因?该如何解决?
  • Gin 路由注册与请求参数获取
  • Linux第11步_解决“挂载后的U盘出现中文乱码”
  • 【第一节】安装java jdk 21
  • vue3+echart绘制中国地图并根据后端返回的坐标实现涟漪动画效果
  • HCIA-Datacom题库(自己整理分类的)_09_Telent协议【13道题】
  • Git专栏篇
  • Java-字符串-String类
  • ubuntu安装docker指定版本
  • 说一下 jsp 的 4 种作用域?
  • 性能分析与调优: Linux 使用ELRepo升级CentOS内核
  • 【【RTC实时时钟实验 -- 在HDMI上显示-FPGA 小实验】】
  • Flutter 图片和资源的高效使用指南