MySQL UNION使用介绍及示例

news2024/11/23 2:42:28

MySQL UNION使用介绍及示例

  • 1 用法介绍
  • 2 使用示例
    • 2.1 数据准备
    • 2.2 查询示例

1 用法介绍

说明
作用UNION运算符用于组合两个或更多SELECT语句的结果集
使用前提UNION中的每个SELECT语句必须具有相同的列数
1. 这些列的数据类型必须兼容:类型不必完全相同,但是必须可以隐式转换。
2. 每个SELECT语句中的列也必须以相同的顺序排列
UNION 语法SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;
UNION ALL语法SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;
UNION 和 UNION ALL区别union 会自动压缩多个结果集合中的重复结果,而 union all 则将所有的结果全部显示出来,不管是不是重复

2 使用示例

2.1 数据准备

  • 测试数据库表:test_onion
  • 数据库数据:
    在这里插入图片描述

2.2 查询示例

  • 假定查询需求:查找各部门男生人数和女生人数,即结果列为部门名称、男生人数、女生人数

  • 查询各部门男生人数:

SELECT
	org_name, count(user_sex) as man_num
FROM
	test_union
where user_sex = '男'
GROUP BY org_name;

在这里插入图片描述

  • 查询各部门女生人数:
SELECT
	org_name, count(user_sex) as woman_num
FROM
	test_union
where user_sex = '女'
GROUP BY org_name;

在这里插入图片描述

  • 将两次的结果整合:
SELECT
	org_name,
	man_num,
	woman_num
FROM
	(
		SELECT
			org_name,
			count(user_sex) AS man_num,
			'' AS woman_num
		FROM
			test_union
		WHERE
			user_sex = '男'
		GROUP BY
			org_name
		UNION ALL
			SELECT
				org_name,
				'' AS man_num,
				count(user_sex) AS woman_num
			FROM
				test_union
			WHERE
				user_sex = '女'
			GROUP BY
				org_name
	) c

整合结果如下:
在这里插入图片描述

但是,如上结果可以看到,两部分数据是完全拼接的,理想的结果是同一个部门的男女数据在一条查询结果上,修改后如下:

SELECT
	org_name,
	SUM(man_num) as man_num,
	SUM(woman_num) as woman_num
FROM
	(
		SELECT
			org_name,
			count(user_sex) AS man_num,
			'' AS woman_num
		FROM
			test_union
		WHERE
			user_sex = '男'
		GROUP BY
			org_name
		UNION ALL
			SELECT
				org_name,
				'' AS man_num,
				count(user_sex) AS woman_num
			FROM
				test_union
			WHERE
				user_sex = '女'
			GROUP BY
				org_name
	) c
GROUP BY org_name

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

(八)Spring之IOC控制反转、DI依赖注入介绍和使用(详解)

文章目录 前言SpringSpring IOC 简介BeanIOC 概述IOC 本质理解 Spring IOC 应用IOC xml装配IOC 依赖注入IOC Bean的作用域 IoC 自动装配Bean 的自动装配注解实现自动装配 IoC 使用注解开发模拟实现Spring IoC 前言 “Spring”在不同的上下文中表示不同的事物。它可以用来引用 …

c++继承相关内容(一)

目录 一.相关概念 二.派生类的相关注意事项 多层继承关系 成员对象和多层继承的区别 四.赋值兼容规则 五.继承关系中的构造函数和析构函数 一.相关概念 基类(父类):被继承的类 派生类(子类):新产生的…

JAVA基础学习(六)

第六章 二维数组 目录 第六章 二维数组 1.二维数组 1.1.冒泡排序 1.2.Arrays数组 1.3.多维数组 总结 内容仅供学习交流,如有问题请留言或私信!!!!! 1.二维数组 1.1.冒泡排序 原理:比较…

日撸java_day37

第 37 天: 十字链表 package datastructures.graph;/*** ClassName: OrthogonalList* Package: datastructures.graph* Description: Orthogonal List for directed graph.** Author: luv_x_c* Create: 2023/5/28 14:53*/ public class OrthogonalList {/*** An inner class f…

chatgpt赋能python:Python图像分割——了解图像分割技术和Python实现

Python图像分割——了解图像分割技术和Python实现 图像分割是一种图像处理技术,它将一幅图像分成若干个区域,每个区域有自己的特征和属性。在图像处理中,图像分割常被用来提高图像质量和辨识度,降低图像处理和分析的难度&#xf…

2023年第十五届四川赛区ACM真题及官方题解

给大家看真题前,先给大家看看现场氛围 入场前: 结束后: 还是有点壮观的。 今年四川的ACM在都江堰举办。因为比赛时间很紧张,所以没来得及去公费旅个游哈哈, 不过题目很棒,志愿者效率很高,比赛…

从零手写操作系统之RVOS硬件定时器-05

从零手写操作系统之RVOS硬件定时器-05 RISC-V 定时器中断RISC-V CLINT 介绍寄存器 (Timer 部分)总体框架流程硬件定时器的应用时间管理测试 本系列参考: 学习开发一个RISC-V上的操作系统 - 汪辰 - 2021春 整理而来,主要作为xv6操作系统学习的一个前置基础。 RVOS是…

vm安装Ubuntu以及Ubuntu设置中文

vm安装Ubuntu以及Ubuntu设置中文 Ubuntu 介绍 Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的开源GNU/Linux 操作系统,Ubuntu 是基于GNU/Linux,支持x86、amd64(即x64)和ppc 架构,由全…

基于DICOM标准的医院PACS系统源码

一、基于 DICOM 的 PACS是医学图像归档与通信系统,是实现医学图像自动获取、显示、图像 后处理、传输、存储、查询、检索、写诊断报告、查看成像设备运行状态等功能复合型医学 图像管理系统。 二、PACS可以为医院其他系统提供医学图像,并能够形成图文并茂…

Ansible进阶1——大项目清单管理

文章目录 一、playbook引用主机方式1.1 引用清单主机1.2 引用主机别名1.3 使用通配符引用 二、动态清单三、管理多个清单四、forks和serial五、包含与导入5.1 导入playbook5.2 导入任务文件5.3 包含任务文件5.4 结合变量 一、playbook引用主机方式 清单文件的使用方式很多&…

UNIX网络编程卷一 学习笔记 第十八章 路由套接字

内核中的Unix路由表传统上一直使用ioctl函数访问,但没有ioctl函数请求能获取整个路由表,而netstat等程序通过读取内核的内存获取路由表内容。诸如gated等路由守护进程需要监视由内核收取的ICMP重定向消息(用于在IP网络中通知主机或路由器更优…

【网络】UDP网络服务器

代码的整体逻辑: UDP服务端:udpServer.cc(服务端的调用),udpServer.hpp(服务端的实现) UDP客户端:udpClient.cc(客户端的调用),udpClient.hpp(客户端的实现) 1.udp服务…

Flask中使用Flask-WTF验证JSON对象参数

Flask中使用Flask-WTF验证JSON对象参数 1 安装 Flask-WTF是对WTForms库的扩展,默认只对”form“标签下的表单进行验证。针对当前前后端分离的项目中,json传输参数需要进行二次封装才能使用。 # 安装Flask-WTF包 pip install Flask-WTF2 源代码 2.1 工…

一些忘了的东西(二)

Symbol出现的原因/作用 ①作为属性 避免属性冲突重复,就是使用它来表示唯一值; 问题是我们什么情况下 要保障属性一定不冲突重复 覆盖呢? 在vue里 有this.$ parent ,this.$ options ,this.$ set 这些,使用$命名开头就是想通过命名约定来减少…

BLIP使用教程

文章目录 准备测试示例一示例二: 结论源代码 原理篇: BLIP2-图像文本预训练论文解读 准备 如果无网络需提前下载相关模型 安装torch、transformers pip install torch trtransformers测试 测试blip基于图片生成文本描述能力(Caption&…

《嵌入式系统》知识总结8:寄存器编程方式操纵GPIO

方式1: 查手册找到相关寄存器的地址,自行编写代码,定义指针指向该地址,并根据需要进行寄存器读写。 举例: //方式1举例:自定义GPIOB_ODR寄存器 #define GPIOB_ODR (*(volatile unsigned int *)0x40010C0…

Vivado时序约束基础

今天这篇博客,笔者向大家简单介绍Xilinx FPGA中的Vivado时序约束基础知识,也为后续的学习打好铺垫。 Xilinx Design Constraints (XDC) 概述 • XDC 在本质上就是Tcl 语言,但其仅支持基本的Tcl 语法,如变量、列表和运算符等等&a…

Go 语言基础

文章目录 Go 语言基础1. 程序基础2. 数据类型3. 字符串与复合数据类型4. 函数、方法、接口和反射5. 并发编程(核心重点)6. 包和代码测试7. 综合实战案例框架部分探索深度 Go 语言基础 1. 程序基础 了解常量和遍历【const var 关键词】 : 初始化以及赋值…

微服务如何治理

微服务远程调用可能有如下问题: 注册中心宕机; 服务提供者B有节点宕机; 服务消费者A和注册中心之间的网络不通; 服务提供者B和注册中心之间的网络不通; 服务消费者A和服务提供者B之间的网络不通; 服务提供者…