需求描述

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

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

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

测试结果

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个线程来查询,应该也就是一个线程串行执行吧。

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

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄