阅读(2112) (13)

Mycat2 UnionAll

2021-09-09 15:14:55 更新

在不跨数据库的情况下,涉及到多个分表合拼的时候,可以有多个选择,常用的是在Mycat中开启多个后端连接然后使用把返回的行汇总在一起或者在数据库中使用集合运算把分表的数据汇总.上述两种,Mycat2都支持.

在同一个数据库上涉及多个分表,Mycat2会使用union all语法把多个生成的SQL连接起来生成一个新的SQL让数据库执行.

Mycat2可以配置生成的每个SQL中出现union all的数量,默认值是5个,它可以汇总6个SQL(表),假如一年分12个表,5union all可以汇总半年数据.

在数据库中的union all实际运行效率取决于存储节点的实现,而不使用union all汇总的数据使用多个连接并行查询汇总或者一个连接依次读取行数据汇总.

另外,union all可以大大减少后端数据库连接的使用量.

每个sql使用的union all数量可以在server的配置中更改