一、背景
最近出现了一个 in 元素过多导致全表扫的案例,根本原因是 range_optimizer_max_mem_size 的影响,详见文档
二、详解
range_optimizer_max_mem_size
- 值为 0 表示"无限制" 。
- 当该值大于 0 时,优化器会跟踪使用范围访问方法时消耗的内存。如果即将超过指定的限制,则会放弃范围访问方法,转而考虑其他方法,例如全表扫描。这可能并非最优方法。如果发生这种情况,将出现以下警告(其中 N是当前 range_optimizer_max_mem_size 值):
bash
Warning 3170 Memory capacity of N bytes for
'range_optimizer_max_mem_size' exceeded. Range
optimization was not done for this query.
- 对于UPDATE 和 DELETE语句,如果优化器回退到全表扫描并且 sql_safe_updates 启用了系统变量,则会发生错误而不是警告,因为实际上没有使用键来确定要修改哪些行。