5分钟了解MySQL5.7中union all用法的黑科技

作者:乐搏学院Learnbo 时间:2024-01-22 16:53:00 

union all在MySQL5.6下的表现

Part1:MySQL5.6.25


[root@HE1 ~]# MySQL -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server 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 its
affiliates. Other names may be trademarks of their respective
owners.
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)

可以看出,在MySQL5.6版本中,执行结果如下图所示:

5分钟了解MySQL5.7中union all用法的黑科技

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

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

Part1:MySQL5.7.15


[root@HE1 ~]# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 8
Server 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 its
affiliates. Other names may be trademarks of their respective
owners.
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)

可以看出,在MySQL5.7版本中,执行结果如下图所示:

5分钟了解MySQL5.7中union all用法的黑科技

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 7
Server version: 10.1.16-MariaDB MariaDB Server
Copyright (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)

可以看出在MariaDB10.1中,执行结果如下图所示:

5分钟了解MySQL5.7中union all用法的黑科技

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

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

5分钟了解MySQL5.7中union all用法的黑科技

——总结——

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

以上所述是小编给大家介绍的5分钟了解MySQL5.7中union all用法的黑科技网站的支持!

来源:http://blog.csdn.net/learnboc/article/details/70170286

标签:mysql,union,all
0
投稿

猜你喜欢

  • Python使用configparser库读取配置文件

    2022-12-21 20:22:56
  • Python Pandas删除替换并提取其中的缺失值NaN(dropna,fillna,isnull)

    2023-08-11 01:11:34
  • 如何使用Python实现自动化水军评论

    2022-08-25 21:15:48
  • 深入理解r2dbc在mysql中的使用

    2024-01-26 20:14:10
  • python 多态 协议 鸭子类型详解

    2023-10-03 11:53:00
  • python中的字典操作及字典函数

    2023-02-06 05:17:42
  • 建立用户体验过程的实用指南

    2007-11-19 12:53:00
  • PL/SQL编程经验小结开发者网络Oracle

    2010-07-18 13:27:00
  • tkinter如何实现label超链接调用浏览器打开网址

    2023-04-05 15:08:20
  • Tkinter组件Checkbutton的具体使用

    2023-03-19 14:55:46
  • python中的pyc文件是什么

    2021-05-12 16:18:57
  • python基础入门之字典和集合

    2022-02-21 03:47:19
  • 用Python的Django框架编写从Google Adsense中获得报表的应用

    2022-10-01 13:20:07
  • Python搭建代理IP池实现检测IP的方法

    2023-10-05 04:42:51
  • Python使用Dijkstra算法实现求解图中最短路径距离问题详解

    2022-07-31 02:40:33
  • python爬虫爬取快手视频多线程下载功能

    2021-10-29 09:24:04
  • 详细讲解HDFS的高可用机制

    2023-11-13 03:37:47
  • Python画图高斯分布的示例

    2023-02-07 09:09:14
  • ASP使用fso遍历文件及文件夹列出文件名

    2008-10-27 19:32:00
  • python制作小说爬虫实录

    2023-09-30 17:39:25
  • asp之家 网络编程 m.aspxhome.com