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的两个子查询是否并行的主要内容,如果未能解决你的问题,请参考以下文章