union的两个子查询是否并行

Posted 阿尔卑斯Love

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了union的两个子查询是否并行相关的知识,希望对你有一定的参考价值。

需求描述

问题:subquery 1 union subquery2,其中union左右的两个子查询是否并行。

场景:业务中性能敏感的业务,希望能加快速度,如果数据库能两个子查询并行执行,既可以节省时间,还可以节省网络开销

测试结果

mysql> select version();
+---------------+
| version()     |
+---------------+
| 5.7.21-21-log |
+---------------+
1 row in set (0.00 sec)

mysql> select sleep(2) union select sleep(5);
+----------+
| sleep(2) |
+----------+
|        0 |
+----------+
1 row in set (7.01 sec)    -- 串行,妥了

分析:mysql是一个连接分配一个进程,这样的一个SQL也不会分成2个线程来查询,应该也就是一个线程串行执行吧。

解决:业务要想快,维护一个连接池,发两个连接到服务端,客户端再去做聚合。

以上是关于union的两个子查询是否并行的主要内容,如果未能解决你的问题,请参考以下文章

UNION是否在并行执行的不同表中有两个SELECT?

是否可以在 Postgres 中执行并行查询,使用 union all 查询分区表?

关于MySQL的关联查询

带有 UNION 子查询的 MAX 不会产生所需的结果

并行LINQ PLinq

mysql学习之路_联合查询与子查询