mysql参数-优化器 range_optimizer_max_mem_size 相关

一、背景

最近出现了一个 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 启用了系统变量,则会发生错误而不是警告,因为实际上没有使用键来确定要修改哪些行。
相关推荐
PaperData6 小时前
2012-2022年农业产业结构高级化
数据库·人工智能·数据分析·经管
喝可乐的希饭a6 小时前
MYSQL的mvcc
数据库·mysql
冷小鱼6 小时前
Valkey 深度剖析:Redis 最佳平替的技术全景
数据库·redis·缓存·valkey
Deryck_德瑞克6 小时前
Nacos适配Kingbase数据库
数据库·windows
hashiqimiya6 小时前
postgres数据库操作指南
数据库
Bert.Cai6 小时前
MySQL MOD()函数详解
数据库·mysql
William Dawson6 小时前
【MySQL触发器超详细实战教程|从零基础到项目生产可用(避坑+案例+跨库+逗号拆分)】
数据库·mysql
.柒宇.6 小时前
AI 掘金头条项目-新闻模块实现
数据库·后端·python·fastapi
许彰午6 小时前
我手写了一个 Java 内存数据库(四):索引引擎、SQL 解析与总结
java·数据库·sql