使用注意,先说结果:

UNION 操作符用于合并两个或多个 SELECT 语句的结果集,这里需要注意的是:

  • UNION 内部的 SELECT 语句必须拥有相同数量的列;
  • 列也必须拥有相似的数据类型(实际非必须);
  • 同时,每条 SELECT 语句中列的顺序必须相同。

一、表结构数据准备如下:

1.1 test_union_1

结构:

  1. CREATE TABLE `test_union_1` (
  2. `one` varchar(255) DEFAULT NULL,
  3. `two` varchar(255) DEFAULT NULL,
  4. `three` varchar(255) DEFAULT NULL,
  5. `four` varchar(255) DEFAULT NULL
  6. ) ENGINE=InnoDB DEFAULT CHARSET=latin1;

数据:

1.2 test_union_2

结构:

  1. CREATE TABLE `test_union_2` (
  2. `four` varchar(255) DEFAULT NULL,
  3. `three` varchar(255) DEFAULT NULL,
  4. `two` varchar(255) DEFAULT NULL,
  5. `one` varchar(255) DEFAULT NULL
  6. ) ENGINE=InnoDB DEFAULT CHARSET=latin1;

数据:

两表数据一致,字段一致,只是字段顺序不同。

test_union_1的顺序:one,two,three,four

test_union_2 的顺序:four,three,two,one

二、验证

2.1、验证:UNION 内部的 SELECT 语句必须拥有相同数量的列;

2.2、验证:列也必须拥有相似的数据类型(实际非必须);

这个实际非必须。

修改表test_union_2 结构如下:String类型改为int类型。

  1. CREATE TABLE `test_union_2` (
  2. `four` int(255) DEFAULT NULL,
  3. `three` int(255) DEFAULT NULL,
  4. `two` int(255) DEFAULT NULL,
  5. `one` int(255) DEFAULT NULL
  6. ) ENGINE = InnoDB CHARSET = latin1;

查询:

  1. SELECT *
  2. FROM (
  3. SELECT one, two, three, four
  4. FROM test_union_1
  5. UNION ALL
  6. SELECT one, two, three, four
  7. FROM test_union_2
  8. ) T;

结果:

所以,实际不是字段类型必须一致,只要可以转换即可。具体转换逻辑暂时不清楚,后续遇到了再搞。

2.3、验证:每条 SELECT 语句中列的顺序必须相同(亲身踩坑)。

先来说下,如果顺序不同,会是什么结果?

答:结果字段的顺序以 union all 前面的表字段顺序为准。

union all 后面的表的数据会按照顺序依次附在后面。注意:按照字段顺序匹配,而不是按照字段名称匹配。

测试如下:表顺序对结果的影响

2.1 test_union_1 UNION ALL test_union_2

  1. SELECT *
  2. FROM (
  3. SELECT *
  4. FROM test_union_1
  5. UNION ALL
  6. SELECT *
  7. FROM test_union_2
  8. ) T;

结果:

可发现:结果字段是test_union_1的字段顺序:one,two,three,four

2.2 test_union_2 UNION ALL test_union_1

  1. SELECT *
  2. FROM (
  3. SELECT *
  4. FROM test_union_2
  5. UNION ALL
  6. SELECT *
  7. FROM test_union_1
  8. ) T;

结果:

可发现:结果字段是test_union_2的字段顺序:four,three,two,one

综上:union all结果字段的顺序以 union all 前面的表字段顺序为准。union all 后面的表的数据会按照字段顺序依次附在后面,而不是按照字段名称匹配。

我们上面以*来表示顺序的不同,其实你写成不同顺序的字段结果一致。我亲测如此,但是不重复贴结果了。

另外,如果系统中进行了分表,一定要保证各个表的字段顺序一致。特别是修改的时候。否则,如果使用 *汇总查询结果,肯定是会有问题的...亲身踩坑。

Union All 使用注意事项和字段顺序不一致导致的异常的更多相关文章

  1. 解决SpringDataJpa实体类中属性顺序与数据库中生成字段顺序不一致的问题

    一.在application.yml配置中添加数据库根据实体类自动创建数据库表的配置(这里数据库采用MySQL数据库) jpa: database: MYSQL show-sql: true #Hib ...

  2. Mysql中字段类型不一致导致索引无效

    修改后 详细见楼下链接 http://ustb80.blog.51cto.com/6139482/1287847

  3. [慢查优化]建索引时注意字段选择性 & 范围查询注意组合索引的字段顺序

    文章转自:http://www.cnblogs.com/zhengyun_ustc/p/slowquery2.html 写在前面的话: 之前曾说过"不要求每个人一定理解 联表查询(join/ ...

  4. Mysql中用SQL增加、删除字段,修改字段名、字段类型、注释,调整字段顺序总结

    转自:http://www.111cn.net/database/mysql/71648.htm 1.增加一个字段  代码如下 复制代码 //增加一个字段,默认为空 alter table user ...

  5. mysql 添加字段、删除字段、调整字段顺序 转

    ALTER TABLE — 更改表属性添加字段: alter table `user_movement_log`Add column GatewayId int  not null default 0 ...

  6. MySQL 字段常用操作 添加,修改,删除,调整字段顺序

    整理备忘: 添加字段:alter table 表名Add column 字段名 字段类型  默认值 AFTER 字段名 (在哪个字段后面添加) 例子: alter table appstore_sou ...

  7. sqlmap映射继承机制及映射字段顺序与SQL查询字段顺序无关

    <typeAlias alias="TblSpPartsinfo" type="com.bn.car.biz.supply.dao.po.PartsInfoPO&q ...

  8. 关于数据库优化1——关于count(1),count(*),和count(列名)的区别,和关于表中字段顺序的问题

    1.关于count(1),count(*),和count(列名)的区别 相信大家总是在工作中,或者是学习中对于count()的到底怎么用更快.一直有很大的疑问,有的人说count(*)更快,也有的人说 ...

  9. oracle数据库调整字段顺序

    oracle数据库调整字段顺序 https://blog.csdn.net/xiaobaixie/article/details/77892034

随机推荐

  1. Sql Server中REPLACE函数的使用

    在sql的使用过程当中,我们偶尔会遇到这样一种情况,就是需要改变数据的存储形式,比如数据库某一张表(Info)当中有一个字段Educational(学历),以前存储的是Json数组,现在由于需求的改变 ...

  2. 8、Spring Boot 2.x 服务器部署

    1.8 服务器部署 完整源码: Spring-Boot-Demos 1.8.1 jar包提取出来maven打包(避免每次重复打相同的jar包),pom.xml配置如下: <build> & ...

  3. 为什么用到springboot?

  4. Gradle 发布 Jar 到 Archiva 时提示不能 Overwriting released artifacts is not allowed

    系统提示错误信息: Received status code 409 from server: Overwriting released artifacts is not allowed. 这是在 A ...

  5. python实现随机生成头像

    今天遇到如何给用户分配随机头像的问题,想着要在本地放很多图片,有点无聊,就找了一些生成头像的工具.发现gravatar生成图像还不错,挺好玩的. 1.下面上代码 # -*- coding: utf-8 ...

  6. CF1140F Extending Set of Points 【按时间分治,并查集】

    题目链接:洛谷 首先我们考虑没有撤回操作的情况,就是将每一行和每一列看做一个点(代表行的称为白点,代表列的称为黑点),每个点$(x,y)$看做一条边. Extend操作实际上就是$x_1$行与$y_1 ...

  7. Codeforces Round #564 比赛总结

    这次是中国大佬出题,结果被虐惨了. A. Nauuo and Votes #include<bits/stdc++.h> #define Rint register int using n ...

  8. hive安装常见错误

    hive编译出错 mvn clean package -DskipTests -Phadoop-2 -Pdist 失败日志1 Failed to execute goal on project hiv ...

  9. Vs中包含目录、库目录、附加包含目录、附加库目录、附加依赖项之详解

    VS项目中的包含目录.库目录.附加包含目录.附加库目录.附加依赖项均在"项目->属性->配置属性"下进行配置,具体说明如下: VC++目录: 包含目录:寻找#inclu ...

  10. 三个div并排

    css: .div-inline{ display:inline} html: <div class="div-inline">第一个div盒子</div> ...