UNION和UNION ALL的用法与区别

前言

MySQL中,可以使用UNIONUNION ALL查询多多条结果,并且它们的结果组合成单个结果集。合并时,两个表对应的列数和数据类型必须相同

使用

1、 建立light_devcice

sql 复制代码
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for light_device
-- ----------------------------
DROP TABLE IF EXISTS `light_device`;
CREATE TABLE `light_device`  (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `tenant_id` bigint NULL DEFAULT NULL COMMENT '租户ID',
  `org_id` bigint NOT NULL COMMENT '机构ID',
  `host_id` bigint NOT NULL COMMENT '网关设备ID',
  `device_id` bigint NOT NULL COMMENT '设备ID',
  `parent_device_id` bigint NULL DEFAULT NULL COMMENT '父设备ID',
  `device_name` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '设备名称',
  `device_remark` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '设备备注',
  `device_sn` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '设备唯一标识',
  `device_type` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '设备类型',
  `device_category` int NULL DEFAULT NULL COMMENT '设备分类',
  `region_id` bigint NULL DEFAULT NULL COMMENT '区域ID',
  `display_flag` tinyint NULL DEFAULT 1 COMMENT '是否显示(网关):1>显示;0>不显示',
  `terminal_flag` tinyint NULL DEFAULT 0 COMMENT '带终端设备能力:1>是;0>否',
  `control_flag` tinyint NULL DEFAULT 0 COMMENT '控制能力:1>是;0>否',
  `delete_flag` tinyint NULL DEFAULT 0 COMMENT '是否删除:1:是;0否',
  `create_by` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '创建人',
  `update_by` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '更新人',
  `create_time` datetime NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `update_time` datetime NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  `saas_device_id` bigint NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE INDEX `device_id_UNIQUE`(`device_id` ASC) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1899370485329244162 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin ROW_FORMAT = DYNAMIC;

SET FOREIGN_KEY_CHECKS = 1;

2、建立light_device_property

sql 复制代码
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for light_device_property
-- ----------------------------
DROP TABLE IF EXISTS `light_device_property`;
CREATE TABLE `light_device_property`  (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `tenant_id` bigint NULL DEFAULT NULL COMMENT '租户ID',
  `org_id` bigint NOT NULL COMMENT '机构ID',
  `host_id` bigint NULL DEFAULT NULL COMMENT '网关ID',
  `device_sn` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '设备唯一标识',
  `device_id` bigint NOT NULL COMMENT '设备ID',
  `device_key` int NOT NULL COMMENT '设备属性ID',
  `property_name` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '属性名称',
  `property_remark` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '设备备注',
  `display_flag` tinyint NULL DEFAULT 1 COMMENT '是否显示(网关):1>显示;0>不显示',
  `delete_flag` tinyint NULL DEFAULT 0 COMMENT '是否删除:1:是;0否',
  `region_id` bigint NOT NULL COMMENT '区域ID',
  `create_by` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '创建人',
  `update_by` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NULL DEFAULT NULL COMMENT '更新人',
  `create_time` datetime NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `update_time` datetime NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  `load_dev_type` int NULL DEFAULT NULL COMMENT '终端设备类型:开关量输入设备、继电器输出设备类型、无线终端设备类型。',
  `saas_device_id` bigint NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1897904309122183171 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin ROW_FORMAT = DYNAMIC;

SET FOREIGN_KEY_CHECKS = 1;

使用union查询

css 复制代码
  select p.id              as propertyId,
        p.device_id       as deviceId,
        p.property_name   as deviceName,
        p.device_key      as deviceKey,
        p.property_remark as deviceRemark,
        p.host_id as hostId,
        p.load_dev_type as deviceType,
        p.display_flag as display,
        p.saas_device_id as saasDeviceId
        from light_device_property p
        where p.org_id = 1853960415193595905
        
         union
        select p.id              as propertyId,
        p.device_id       as deviceId,
        p.device_name   as deviceName,
        null as deviceKey,
        p.device_remark as deviceRemark,
        p.host_id as hostId,
        p.device_type as deviceType,
        p.display_flag as display,
        p.saas_device_id as saasDeviceId
        from light_device p
        where p.org_id = 1853960415193595905

返回值为

如果使用该sql

csharp 复制代码
  select p.id              as propertyId
        from light_device_property p
        where p.org_id = 1853960415193595905
        
         union
        select p.id              as propertyId
        from light_device p
        where p.org_id = 1853960415193595905

会发现如果两个表有重复id,不会出现重复记录

css 复制代码
 select p.id              as propertyId
        from light_device_property p
        where p.org_id = 1853960415193595905
        
         union all
        select p.id              as propertyId
        from light_device p
        where p.org_id = 1853960415193595905

会发现如果两个表有重复id,会出现重复记录

总结

UNION 从查询结果集中自动去除了重复的行,如果要返回所有匹配行,而不进行删除,可以使用 UNION ALL。

相关推荐
睡觉的时候不会困1 小时前
Redis 主从复制详解:原理、配置与主从切换实战
数据库·redis·bootstrap
程序员爱钓鱼2 小时前
Go语言实战案例 — 工具开发篇:实现一个图片批量压缩工具
后端·google·go
程序员的世界你不懂3 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
自学也学好编程3 小时前
【数据库】Redis详解:内存数据库与缓存之王
数据库·redis
福赖3 小时前
《MySQL基础——用户管理》
mysql·用户管理
JAVA不会写4 小时前
在Mybatis plus中如何使用自定义Sql
数据库·sql
IT 小阿姨(数据库)4 小时前
PgSQL监控死元组和自动清理状态的SQL语句执行报错ERROR: division by zero原因分析和解决方法
linux·运维·数据库·sql·postgresql·centos
ChinaRainbowSea4 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
舒一笑4 小时前
同步框架与底层消费机制解决方案梳理
后端·程序员
minh_coo4 小时前
Spring框架事件驱动架构核心注解之@EventListener
java·后端·spring·架构·intellij-idea