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 启用了系统变量,则会发生错误而不是警告,因为实际上没有使用键来确定要修改哪些行。
相关推荐
摇滚侠8 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
麦聪聊数据10 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
ApacheSeaTunnel10 小时前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
shushangyun_10 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡10 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧11 小时前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon11 小时前
SQL学习指南——视图
数据库·sql
活宝小娜11 小时前
mysql详细安装教程
数据库·mysql·adb
贤时间11 小时前
codex 助力oracle ebs 开发
数据库·oracle
秉承初心12 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle