union all在MySQL5.6下的表现

Part1:MySQL5.6.25

[root@HE1 ~]# MySQL -uroot -pEnter password: Welcome to the MySQL monitor. Commands end with ; or \g.Your MySQL connection id is 2Server version: 5.6.25-log MySQL Community Server (GPL)Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> select version();+------------+| version() |+------------+| 5.6.25-log |+------------+1 row in set (0.26 sec)  mysql> explain (select id from helei order by id) union all (select id from t where id=0 order by id);+----+--------------+------------+-------+---------------+--------+---------+------+------+-----------------+| id | select_type | table   | type | possible_keys | key  | key_len | ref | rows | Extra      |+----+--------------+------------+-------+---------------+--------+---------+------+------+-----------------+| 1 | PRIMARY   | helei   | index | NULL     | idx_c1 | 4    | NULL | 5219 | Using index   || 2 | UNION    | t     | ALL  | NULL     | NULL  | NULL  | NULL |  1 | Using where   || NULL | UNION RESULT | <union1,2> | ALL  | NULL     | NULL  | NULL  | NULL | NULL | Using temporary |+----+--------------+------------+-------+---------------+--------+---------+------+------+-----------------+3 rows in set (0.00 sec)

wKioL1f8bZvhzEMaAAFulp6pefo997.jpg

从执行计划来看,是把helei表的查询结果和t表的查询结果合并在了一张临时表里,然后输出给客户端。

union all在MySQL5.7/MariaDB10.1下的表现

Part1:MySQL5.7.15

[root@HE1 ~]# mysql -uroot -pEnter password: Welcome to the MySQL monitor. Commands end with ; or \g.Your MySQL connection id is 8Server version: 5.7.15-log MySQL Community Server (GPL)Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> select version();+------------+| version() |+------------+| 5.7.15-log |+------------+1 row in set (0.00 sec)、mysql> explain (select id from helei order by id) union all (select id from t where id=0 order by id);+----+-------------+-------+------------+-------+---------------+--------+---------+------+------+----------+-------------+| id | select_type | table | partitions | type | possible_keys | key  | key_len | ref | rows | filtered | Extra    |+----+-------------+-------+------------+-------+---------------+--------+---------+------+------+----------+-------------+| 1 | PRIMARY   | helei | NULL    | index | NULL     | idx_c1 | 4    | NULL | 5212 |  100.00 | Using index || 2 | UNION    | t   | NULL    | ALL  | NULL     | NULL  | NULL  | NULL |  1 |  100.00 | Using where |+----+-------------+-------+------------+-------+---------------+--------+---------+------+------+----------+-------------+2 rows in set, 1 warning (0.00 sec)

wKiom1f8bijj3fJiAAF48HG3WPQ918.jpg

Part2:MariaDB10.1.16

[root@HE3 ~]# /usr/local/mariadb/bin/mysql -uroot -S /tmp/mariadb.sock Welcome to the MariaDB monitor. Commands end with ; or \g.Your MariaDB connection id is 7Server version: 10.1.16-MariaDB MariaDB ServerCopyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.MariaDB [(none)]>MariaDB [helei]> explain (select id from helei order by id) union all (select id from t where id=0 order by id);+------+-------------+-------+-------+---------------+--------+---------+------+------+-------------+| id  | select_type | table | type | possible_keys | key  | key_len | ref | rows | Extra    |+------+-------------+-------+-------+---------------+--------+---------+------+------+-------------+|  1 | PRIMARY   | helei | index | NULL     | idx_c1 | 4    | NULL | 5198 | Using index ||  2 | UNION    | t   | ALL  | NULL     | NULL  | NULL  | NULL |  1 | Using where |+------+-------------+-------+-------+---------------+--------+---------+------+------+-------------+2 rows in set (0.00 sec)

wKioL1f8bmmwi9GLAAFbMJCN0uU554.jpg

从执行结果看,无论是MySQL5.7还是MariaDB10.1,都没有创建临时表,按照顺序,helei表的查询结果首先输出到客户端,然后t表的查询结果再输出到客户端。

本文中的优化只针对union all,对union和在最外层使用order by无效。如下图是所示:

wKiom1f8boazPx35AAKnKQS1Ig4776.jpg

——总结——

在MySQL5.7/MariaDB10.1中,union all不再创建临时表,这样在联合查询时会减少I/O开销,在MySQL5.5/5.6中则不具备这一特性。

更多相关文章

  1. 关于android contentprovider 多线程读取问题
  2. 那些年Android黑科技①:只要活着,就有希望
  3. Android黑科技动态加载(三)之动态加载资源
  4. Android黑科技动态加载(四)之动态启动插件Activity
  5. Android(安卓)黑科技
  6. Android探索与黑科技
  7. Android黑科技动态加载(二)之Android中的ClassLoader
  8. 意派Epub360丨【活动】黑科技的双11新玩法,H5+VR福利限时抢!更有千
  9. 招聘h5页面是什么?这支科技感招聘H5模板助你在线制作招聘H5活动页

随机推荐

  1. Android 下 Kernel Debug (Qualcomm Chip
  2. Android ListView移动至指定行
  3. Android 滑动效果入门篇(二)
  4. Android10共享文件总是读取不到文件,文件
  5. android 输入系统
  6. Android 入门 和 环境搭建
  7. Cordova 低版本安卓白屏
  8. Android 开发环境安装 新版本Android Stu
  9. 《第一行代码——Android》
  10. Android获取其他包的Context实例