1 union 的作用


union 运算符用于组合两个或更多 select 语句的结果集。


2 union 使用前提


union 中的每个 select 语句必须具有相同的列数

  • 这些列也必须具有相似的数据类型
  • 每个 select 语句中的列也必须以相同的顺序排列

3 union 语法


select column_name(s) from table1
union
select column_name(s) from table2;
注释:默认情况下,union 运算符选择一个不同的值。如果允许重复值,请使用union all。

4 UNION ALL 语法

select column_name(s) from table1
union all
select column_name(s) from table2;
注释:UNION 结果集中的列名总是等于 UNION 中第一个 select 语句中的列 名。

5 示例数据


以下是"customers" 表中的数据:
csdn=> select * from customers;id |  name  |     addr      | city |  zip   | province
----+--------+---------------+------+--------+----------1 | 鲁智深 | 北京路27号    | 平凉 | 200000 | 甘肃省2 | 李四   | 南京路12号    | 杭州 | 310000 | 浙江市3 | 王五   | 花城大道17号  | 广州 | 510000 | 广州省4 | 马六   | 江夏路19号    | 武汉 | 430000 | 湖北省5 | 赵七   | 西二旗12号    | 北京 | 100000 | 北京市6 | 宋一   | 花城大道21号  | 广州 | 510000 | 广东省7 | 刘二   | 长安街 121 号 | 北京 | 100000 | 北京市8 | 宋江   | 梁山路1号     | 济南 | 250000 | 山东省| 武松   |               | 邢台 |        | 河北省10 | 韩信   | 梁山路1号     | 渝东 | 250001 | 四川省11 | 吕不韦 | 梁山路1号     | 渝中 | 250001 | 四川省
(11 rows)csdn=>

选自 "suppliers" 表的数据:

csdn=> select * from suppliers;id |   name   |     addr     | city |  zip   | province
----+----------+--------------+------+--------+----------1 | 沃尔玛   | 北京路35号   | 上海 | 200000 | 上海市2 | 家乐福   | 玄武街28号   | 南京 | 210000 | 江苏省3 | 永旺超市 | 花城大道21号 | 广州 | 710000 | 广东省4 | 宋江超市 | 梁山路1号    | 济南 | 250000 | 山东省
(4 rows)csdn=>

6 union 举证


以下 sql 语句从 "customers" 和"suppliers" 表中选择所有不同的城市(只有不同的值):

select city from customers
union
select city from suppliers;

结果:

注:

不能用 union来列出两个表中的所有城市。如果一些客户和供应商来自同一个城市,每个城市将只被列入一个列表。union 将只选择不同的值,即会排除重复数据只保留一个。请使用 union all 选择重复值!

7 union all 实例


以下 sql语句使用union all 从 "customers"和"suppliers" 表中选择所有城市(也是重复的值):

select city as "城市" from customers
union all
select city from suppliers;

结果:

8 带有 where 的 union all


以下 sql 语句使用 unionall 从"customers"和 "suppliers" 表中选择所有上海市的城市(也是重复数值):

举例:

select city as "城市", province as "省份" from customers
where province='广东省'
union all
select city, province from suppliers
where province='广东省';

结果:

9 带有 where 的union


以下 sql 语句从"客户"和"供应商"中选择所有不同的上海城市(只有不同的值):

select city as "城市", province as "省份" from customers
where province='广东省'
union
select city, province from suppliers
where province='广东省';


结果:

10 批注


union 就是将多段功能类似的 sql 连接起来,并且可以去掉重复的行,有distinct 的功能。union all 则只是单纯的将多段类似 sql 连接起来,而且他们的好处是可以将复杂 sql 按不同的功能或作用拆分成一小段 sql 进行拼接,可以有效提高查询效率。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/92018.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/92018.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/92018.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

构建足球实时比分APP:REST API与WebSocket接入方案详解

在开发足球实时比分应用时,数据接入方式的选择直接影响用户体验和系统性能。本文将客观分析REST API和WebSocket两种主流接入方案的技术特点、适用场景和实现策略,帮助开发者做出合理选择。一、REST API:灵活的数据获取方案核心优势标准化接口…

Linux文件系统三要素:块划分、分区管理与inode结构解析

理解文件系统 我们知道文件可以分为磁盘文件和内存文件,内存文件前面我们已经谈过了,下面我们来谈谈磁盘文件。 目录 一、引入"块"概念 解析 stat demo.c 命令输出 基本信息 设备信息 索引节点信息 权限信息 时间戳 二、引入"分区…

基于paddleDetect的半监督目标检测实战

基于paddleDetect的半监督目标检测实战前言相关介绍前提条件实验环境安装环境项目地址使用paddleDetect的半监督方法训练自己的数据集准备数据分割数据集配置参数文件PaddleDetection-2.7.0/configs/semi_det/denseteacher/denseteacher_ppyoloe_plus_crn_l_coco_semi010.ymlPa…

计算机网络:(十)虚拟专用网 VPN 和网络地址转换 NAT

计算机网络:(十)虚拟专用网 VPN 和网络地址转换 NAT前言一、虚拟专用网 VPN1. 基础概念与作用2. 工作原理3. 常见类型4. 协议对比二、NAT:网络地址转换1. 基础概念与作用2. 工作原理与类型3. 优缺点与问题4. 进阶类型三、VPN 与 N…

数位 dp

数位dp 特点 问题大多是指“在 [l,r][l,r][l,r] 的区间内,满足……的数字的个数、种类,等等。” 但是显然,出题人想要卡你,rrr 肯定是非常大的,暴力枚举一定超时。 于是就有了数位 dp。 基本思路 数位 dp 说白了…

Selector的用法

Selector的用法 Selector是基于lxml构建的支持XPath选择器、CSS选择器&#xff0c;以及正则表达式&#xff0c;功能全面&#xff0c;解析速度和准确度非常高 from scrapy import Selectorbody <html><head><title>HelloWorld</title></head>&…

Netty封装Websocket并实现动态路由

引言 关于Netty和Websocket的介绍我就不多讲了,网上一搜一大片。现如今AI的趋势发展很热门,长连接对话也是会经常接触到的,使用Websocket实现长连接,那么很多人为了快速开发快速集成就会使用spring-boot-starter-websocket依赖快速实现,但是注意该实现是基于tomcat的,有…

行为型设计模式:解释器模式

解释器模式 解释器模式介绍 解释器模式使用频率不算高&#xff0c;通常用来描述如何构建一个简单“语言”的语法解释器。它只在一些非常特定的领域被用到&#xff0c;比如编译器、规则引擎、正则表达式、SQL 解析等。不过&#xff0c;了解它的实现原理同样很重要&#xff0c;能…

SaTokenException: 未能获取对应StpLogic 问题解决

&#x1f4dd; Sa-Token 异常处&#xff1a;未能获取对应StpLogic&#xff0c;typeuser&#x1f9e8; 异常信息 cn.dev33.satoken.exception.SaTokenException: 未能获取对应StpLogic&#xff0c;typeuser抛出位置&#xff1a; throw new SaTokenException("未能获取对应S…

Web前端性能优化原理与方法

一、概述 1.1 性能对业务的影响 大部分网站的作用是&#xff1a;产品信息载体、用户交互工具或商品流通渠道。这就要求网站与更多用户建立联系&#xff0c;同时还要保持良好的用户黏性&#xff0c;所以网站就不能只关注自我表达&#xff0c;而不顾及用户是否喜欢。看看网站性…

第十八节:第六部分:java高级:注解、自定义注解、元注解

认识注解自定义注解注解的原理元注解常用的两个元注解代码&#xff1a; MyTest1&#xff08;注解类&#xff09; package com.itheima.day10_annotation;import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.Retent…

北京科技企业在软文推广发稿平台发布文章,如何精准触达客户?

大家好&#xff01;我是你们的老朋友&#xff0c;今天咱们聊聊北京科技企业如何通过软文推广发稿平台精准触达目标客户这个话题。作为企业营销的老司机&#xff0c;我深知在这个信息爆炸的时代&#xff0c;如何让你的品牌声音被目标客户听到是多么重要。下面就让我来分享一些实…

UE蒙太奇和动画序列有什么区别?

在 UE5 中&#xff0c;Animation Sequence&#xff08;动画序列&#xff09;和 Animation Montage&#xff08;动画蒙太奇&#xff09;虽然都能播放骨骼动画&#xff0c;但它们的定位、功能和使用场景有较大区别&#xff1a;1. 概念定位Animation Sequence&#xff08;动画序列…

Nordic打印RTT[屏蔽打印中的<info> app]

屏蔽打印中的 app Nordic原装的程序答应是这样的,这个有" app"打印,因为习惯问题,有时候也不想打印太多造成RTT VIEW显示被冲点,所以要把" app"去掉:这里把prefix_process函数调用屏蔽到,主要涉及到nrf_log_hexdump_entry_process和nrf_log_std_entry_proc…

Python基础和高级【抽取复习】

1.Python 的深拷贝和浅拷贝有什么区别&#xff1f; 浅拷贝【ls.copy()】&#xff1a; 将列表的不可变对象【值】复制一份&#xff0c;同时引用其中的可变对象【列表】&#xff0c;共用一个内存地址 深拷贝【lscopy.deepcopy(list)】&#xff1a; 完全的复制原可变对象&#xff…

TinyPiXOS组件开发(一):开发规范、组件开发方法介绍,快速上手组件开发,创造各种有趣的UI组件!

本文将通过实现一个点击切换进度的电量指示灯组件和exampleGUI组件库介绍如何基于TinyPiXOS开发新组件。主要内容包括组件开发规范、自定义组件开发和组件库开发三部分。 组件开发规范 命名规范 采用tp开头命名组件类&#xff0c;名称具备易读性。 目录规范 头文件放置 in…

主流熔断方案选型指南

主流熔断方案选型1. Netflix Hystrix (经典但已停止维护)适用场景&#xff1a;传统Spring Cloud项目&#xff0c;需要快速集成熔断功能优点&#xff1a;成熟稳定&#xff0c;社区资源丰富与Spring Cloud Netflix套件无缝集成提供熔断、降级、隔离等完整功能缺点&#xff1a;已停…

Django中get()与filter()对比

在 Django 中&#xff0c;get() 和 filter() 是 QuerySet API 中用于检索数据的两个核心方法&#xff0c;它们的功能和使用场景有明显区别。以下是详细对比&#xff1a; 1. 核心区别特性get()filter()返回值单个对象&#xff08;模型实例&#xff09;查询集&#xff08;QuerySe…

MySQL锁(一) 概述与分类

1.1 MySQL锁的由来 客户端发往 MySQL 的一条条 SQL 语句&#xff0c;实际上都可以理解成一个个单独的事务&#xff08;一条sql语句默认就是一个事务&#xff09;。而事务是基于数据库连接的&#xff0c;每个数据库连接在 MySQL 中&#xff0c;又会用一条工作线程来维护&#x…

PyTorch里的张量及张量的操作

张量的简介 张量是多重线性映射在给定基下的坐标表示&#xff0c;可视为向量和矩阵的泛化。 0 维张量&#xff1a;标量&#xff08;如 5&#xff09;1 维张量&#xff1a;向量&#xff08;如 [1, 2, 3]&#xff09;2 维张量&#xff1a;矩阵&#xff08;如 [[1, 2], [3, 4]]&…