1.2升级2.0.13后查询变慢

Viewed 83

升级2.0.13后大表join小表变慢
下面是查询sql,gsms_msg_ticket_sms是表,其他表都是小表,耗时需要2s左右
如果单查gsms_msg_ticket_sms表,只需要0.5s左右
执行计划,使用的是Shuffle Join
image.png

SELECT
*
FROM
gsms_msg_ticket_sms AS t
JOIN gsms_user AS u  on u.id = t.user_id
LEFT JOIN gsms_user AS e ON u.enterprise_id = e.id
LEFT JOIN gsms_user AS sale ON e.saleman_id = sale.id
LEFT JOIN gsms_user_ext ext ON ext.enterprise_id = e.id
LEFT JOIN gsms_user AS service ON ext.customer_service_id = service.id
LEFT JOIN gsms_user AS success ON ext.customer_success_id = success.id
LEFT JOIN gsms_user AS support ON ext.technical_support_id = support.id
LEFT JOIN gsms_carrier_channel AS c ON c.id = t.channel_id 
WHERE
1 = 1 
AND t.id IN (1275031788812894210,1275031780030023683,1275031775093327876,1275031770693502978,1275031773868589065,1275031773872783361,1275031772203450368,1275031766729883653,1275031750699253762,1275031747222175749
) 
AND t.post_time >= '2024-08-19 00:00:00' 
AND t.post_time <= '2024-08-19 23:59:59' 
AND t.enterprise_id = 234316 
AND (( t.total > 1 AND t.number != 0 ) OR t.total = 1 ) 

ORDER BY
t.post_time DESC,
t.frame_id DESC,
t.phone,
t.ticket_id ASC,
t.number ASC;

强制使用broadcast join
速度就能达到0.5s
执行计划:使用的是broadcastjoin 类型
image.png

SELECT
*
FROM
gsms_msg_ticket_sms AS t
JOIN [broadcast]gsms_user AS u  on u.id = t.user_id
LEFT JOIN [broadcast]gsms_user AS e ON u.enterprise_id = e.id
LEFT JOIN [broadcast]gsms_user AS sale ON e.saleman_id = sale.id
LEFT JOIN [broadcast]gsms_user_ext ext ON ext.enterprise_id = e.id
LEFT JOIN [broadcast]gsms_user AS service ON ext.customer_service_id = service.id
LEFT JOIN [broadcast]gsms_user AS success ON ext.customer_success_id = success.id
LEFT JOIN [broadcast]gsms_user AS support ON ext.technical_support_id = support.id
LEFT JOIN [broadcast]gsms_carrier_channel AS c ON c.id = t.channel_id 
WHERE
1 = 1 
AND t.id IN (1275031788812894210,1275031780030023683,1275031775093327876,1275031770693502978,1275031773868589065,1275031773872783361,1275031772203450368,1275031766729883653,1275031750699253762,1275031747222175749
) 
AND t.post_time >= '2024-08-19 00:00:00' 
AND t.post_time <= '2024-08-19 23:59:59' 
AND t.enterprise_id = 234316 
AND (( t.total > 1 AND t.number != 0 ) OR t.total = 1 ) 

ORDER BY
t.post_time DESC,
t.frame_id DESC,
t.phone,
t.ticket_id ASC,
t.number ASC;

在1.2.7.1下没有使用broadcast执行sql,速度也是0.5s,查看执行计划
也是使用的是broadcast
image.png

请问这个情况怎么处理?

2 Answers

explain 看下2.0.13走的什么优化器?

关注下默认优化器:
执行show variables like "%ner%";

experimental_enable_nereids_planner
enable_fallback_to_original_planner

这两个参数的截图看下。