当连接到一个很小的空的表时,尽管我使用的是“ IMIT”,为什么MySQL仍要进行完整扫描?

当连接到一个很小的空的表时,尽管我使用的是“ IMIT”,为什么MySQL仍要进行完整扫描?,第1张

连接到一个很小的/空的表时,尽管我使用的是“ IMIT”,为什么MySQL仍要进行完整扫描?

MySQL优化器将首先确定连接顺序/方法,然后检查对于所选择的连接顺序是否可以避免通过使用索引进行排序。对于此问题中的慢查询,优化器已决定使用“块嵌套循环”(BNL)连接。

当其中一个表很小(并且没有LIMIT)时,BNL通常比使用索引更快。

但是,对于BNL,行不一定按第一个表给出的顺序排列。因此,连接的结果需要在应用LIMIT之前进行排序。

您可以通过以下方式关闭BNL

set optimizer_switch = 'block_nested_loop=off';



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5649766.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存