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 启用了系统变量,则会发生错误而不是警告,因为实际上没有使用键来确定要修改哪些行。
相关推荐
瀚高PG实验室15 分钟前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)26 分钟前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
敲个大西瓜30 分钟前
Java项目常用数据归档方式
mysql
YOU OU1 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng2 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
kyriewen3 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
小码工作室3 小时前
使用 HAVING 进行 MySQL 集合筛选
mysql
罗超驿3 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-3 小时前
Redis 命令
数据库·redis·缓存
小江的记录本4 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven