The table‘xxxx’is full 设置临时表大小
2014-04-11 16:27
417 查看
tmp_table_size 如果内存内的临时表超过该值,MySQL自动将它转换为硬盘上的MyISAM表。如果你执行许多高级GROUP BY查询并且有大量内存,则可以增加tmp_table_size的值。 max_heap_table_size 该变量设置MEMORY (HEAP)表可以增长到的最大空间大
tmp_table_size
如果内存内的临时表超过该值,MySQL自动将它转换为硬盘上的MyISAM表。如果你执行许多高级GROUP BY查询并且有大量内存,则可以增加tmp_table_size的值。
max_heap_table_size
该变量设置MEMORY (HEAP)表可以增长到的最大空间大小。该变量用来计算MEMORY表的MAX_ROWS值。在已有的MEMORY表上设置该变量没有效果,除非用CREATE TABLE或TRUNCATE TABLE等语句重新创建表。
如何设置:
方法一,修改my.ini或my.cnf
tmp_table_size=64M
max_heap_table_size=32M
此方法最大的缺点,是一旦重启,一切恢复默认值
方法二,mysqld命令行
mysqld_safe --key_buffer_size=512K --sort_buffer_size=16K
--tmp_table_size=64M --max_heap_table_size=32M &
方法三,动态修改
因为tmp_table_size和max_heap_table_size,都有session作用域,所以,一般情况下,尽量这样做吧
SET SESSION tmp_table_size=64*1024*1024
SET SESSION max_heap_table_size=32*1024*1024
修改好后如何查看:
查看服务器配置信息
SHOW VARIABLES WHERE Variable_name LIKE %tmp_table_size%
查看服务器运行信息
SHOW STATUS
如何使用JDBC获得他们的值:
SELECT @@tmp_table_size
SELECT @@max_heap_table_size
#INSERT INTO `useract101` VALUES ('oIAIo', '101 ', '1396520260589', '任务', '', 15, 11, 75128, 209047, 0, 645, 43, 0, '###', 0, '1@39');
#SELECT rolename, count(*) FROM useract101 GROUP BY rolename;
#alter table useract101 max_rows=999999999;
#show table status like 'useract101'
#SHOW VARIABLES LIKE '%max_heap_table_size%'
#SHOW VARIABLES LIKE '%tmp_table_size%'
#SHOW STATUS
#SET SESSION tmp_table_size=64*1024*1024
#SET SESSION max_heap_table_size=32*1024*1024
tmp_table_size
如果内存内的临时表超过该值,MySQL自动将它转换为硬盘上的MyISAM表。如果你执行许多高级GROUP BY查询并且有大量内存,则可以增加tmp_table_size的值。
max_heap_table_size
该变量设置MEMORY (HEAP)表可以增长到的最大空间大小。该变量用来计算MEMORY表的MAX_ROWS值。在已有的MEMORY表上设置该变量没有效果,除非用CREATE TABLE或TRUNCATE TABLE等语句重新创建表。
如何设置:
方法一,修改my.ini或my.cnf
tmp_table_size=64M
max_heap_table_size=32M
此方法最大的缺点,是一旦重启,一切恢复默认值
方法二,mysqld命令行
mysqld_safe --key_buffer_size=512K --sort_buffer_size=16K
--tmp_table_size=64M --max_heap_table_size=32M &
方法三,动态修改
因为tmp_table_size和max_heap_table_size,都有session作用域,所以,一般情况下,尽量这样做吧
SET SESSION tmp_table_size=64*1024*1024
SET SESSION max_heap_table_size=32*1024*1024
修改好后如何查看:
查看服务器配置信息
SHOW VARIABLES WHERE Variable_name LIKE %tmp_table_size%
查看服务器运行信息
SHOW STATUS
如何使用JDBC获得他们的值:
SELECT @@tmp_table_size
SELECT @@max_heap_table_size
#INSERT INTO `useract101` VALUES ('oIAIo', '101 ', '1396520260589', '任务', '', 15, 11, 75128, 209047, 0, 645, 43, 0, '###', 0, '1@39');
#SELECT rolename, count(*) FROM useract101 GROUP BY rolename;
#alter table useract101 max_rows=999999999;
#show table status like 'useract101'
#SHOW VARIABLES LIKE '%max_heap_table_size%'
#SHOW VARIABLES LIKE '%tmp_table_size%'
#SHOW STATUS
#SET SESSION tmp_table_size=64*1024*1024
#SET SESSION max_heap_table_size=32*1024*1024
相关文章推荐
- 第五周自学内容
- 【LeetCode练习题】Longest Valid Parentheses
- 【HTML】Intermediate1:Span&Div
- NPOI 2.0 Excel读取显示
- DevExpress中Tile Application窗体的模型架构图
- knockout——官网demo
- 【转载】每日一句正能量
- 在java中如何用键盘输入一个数,字符,字符串
- 我们了的系统检测到您的计算机网络中存在异常流量.
- postgresql学习笔记一之安装
- 【树】树的概念
- c3p0详细配置
- struts2 I18n问题 国际化
- knockout_主页的demo复习
- [每日一练] Java多线程
- SQLite字段类型
- android定位和地图开发实例
- Project facet Java version 1.7 is not supported.
- android定位和地图开发实例
- Ruby 里的 %Q, %q, %W, %w, %x, %r, %s, %i