0

0

mysql如何修改临时表大小_mysql tmp_table_size调整

P粉602998670

P粉602998670

发布时间:2026-03-01 10:52:03

|

748人浏览过

|

来源于php中文网

原创

mysql不会报tmp_table_size超限错误,而是查询变慢、created_tmp_disk_tables飙升,慢查日志出现using temporary; using filesort;调大需同步设置max_heap_table_size,且受字段类型、索引、连接时效等影响。

mysql如何修改临时表大小_mysql tmp_table_size调整

tmp_table_size 超了会报什么错

MySQL 不会直接报 tmp_table_size 超限的错误,但你会看到查询变慢、磁盘临时表暴增,甚至触发 Created_tmp_disk_tables 指标飙升。更典型的线索是慢查日志里出现 Using temporary; Using filesort,同时 SHOW STATUS LIKE 'Created_tmp%' 显示 Created_tmp_disk_tables 占比持续高于 10%——这说明内存临时表不够用,被迫落盘。

怎么安全调大 tmp_table_size

不能只改 tmp_table_size,它必须和 max_heap_table_size 同步调整,否则以二者中较小值为准。线上调优建议按以下顺序操作:

  • 先查当前值:SELECT @@tmp_table_size, @@max_heap_table_size;
  • 确认可用内存余量(别让单个连接吃光 2GB 内存),建议单次调幅 ≤ 256MB
  • 动态生效(仅对新连接):SET GLOBAL tmp_table_size = 268435456;SET GLOBAL max_heap_table_size = 268435456;
  • 写入配置文件(/etc/my.cnf/etc/mysql/mysql.conf.d/mysqld.cnf)持久化:
    [mysqld]
    tmp_table_size = 268435456
    max_heap_table_size = 268435456

为什么调了还是走磁盘临时表

常见原因不是参数没生效,而是查询本身不满足内存表条件:

赣极购物商城网店建站软件系统
赣极购物商城网店建站软件系统

大小仅1兆左右 ,足够轻便的商城系统; 易部署,上传空间即可用,安全,稳定; 容易操作,登陆后台就可设置装饰网站; 并且使用异步技术处理网站数据,表现更具美感。 前台呈现页面,兼容主流浏览器,DIV+CSS页面设计; 如果您有一定的网页设计基础,还可以进行简易的样式修改,二次开发, 发布新样式,调整网站结构,只需修改css目录中的css.css文件即可。 商城网站完全独立,网站源码随时可供您下载

下载
  • 字段含 TEXTBLOB 类型 → 强制走磁盘,无论 tmp_table_size 多大
  • 使用了 UNIONDISTINCTGROUP BY + 非索引列 → 容易突破内存限制
  • 客户端连接时已建立,SET GLOBAL 不影响旧连接,得重连或用 SET SESSION 单独设
  • innodb_buffer_pool_size 过小导致整体内存紧张,系统主动回收临时表内存

tmp_table_size 对不同存储引擎的影响

这个参数只控制 MEMORY 引擎临时表的上限,和 InnoDB 或 MyISAM 无关。但要注意:

  • InnoDB 查询中产生的内部临时表(如排序、聚合)仍受此值约束,只是底层可能用 InnoDB 格式落盘
  • MyISAM 临时表完全绕过 tmp_table_size,直接写磁盘,所以调大该值对 MyISAM 场景无效
  • 如果 internal_tmp_mem_storage_engine 设为 TempTable(MySQL 8.0.13+ 默认),则受 temp_table_max_ram 控制,而非 tmp_table_size

真正卡住性能的往往不是单个参数值,而是查询是否能避免生成大临时表——比如加索引覆盖 GROUP BY 字段,比盲目调高 tmp_table_size 更有效。参数只是兜底,不是解药。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

682

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

452

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

286

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

264

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

541

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

662

2023.08.14

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

6

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.4万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 838人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号