网站首页 > 基础教程 正文
1 碎片是怎么产生的及查看
在MySQL中.经常update,delete的表就会产生碎片.怎么去确定表中有没有碎片呢?
select TABLE_SCHEMA,
TABLE_NAME TABLE_NAME,
CONCAT(ROUND(data_length / (1024 * 1024), 2),'M') data_length,
CONCAT(ROUND(index_length / (1024 * 1024), 2),'M') index_length,
CONCAT(ROUND(ROUND(data_length + index_length) / (1024 * 1024),2),'M') total_size,
CONCAT(ROUND(data_free / (1024 * 1024), 2),'M') datafree,
engine
FROM INFORMATION_SCHEMA.TABLES
where table_schema='xxx' and table_name='xxx';
其中data_free显示表中空洞的空间.有可能是表碎片,也有可能是未利用到的空间
2 碎片整理的方法
碎片整理有三种方法:
1 alter table xxx engine=innodb; 结合analyze table xx;使用
2 optimize table xxx;
3 将表中数据select出来再插入新表
注意:执行以上操作的时候要避开业务高峰期.不要经常去整理碎片.周期半年左右就可以
3 data_free介绍
information_schema.tables中的data_free这一列.并不能真实的反应空间碎片
要真正对比表碎片的大小.需要用上边语句中的total_size和磁盘上表文件的差值
然后和data_free比较.就可以真实的得出表空间碎片的大小了.
4 扩展介绍
在日常的运维过程中.我们需要实时注意数据库内大表的变化.以下是获取数据库中大表的语句.
SELECT TABLE_SCHEMA,
TABLE_NAME TABLE_NAME,
CONCAT(ROUND(data_length / (1024 * 1024), 2),'M') data_length,
CONCAT(ROUND(index_length / (1024 * 1024), 2),'M') index_length,
CONCAT(ROUND(ROUND(data_length + index_length) / (1024 * 1024),2),'M') total_size,
CONCAT(ROUND(data_free / (1024 * 1024), 2),'M') datafree,
engine
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA NOT IN ('INFORMATION_SCHEMA' ,
'performance_schema',
'sys',
'mysql')
ORDER BY (data_length + index_length ) DESC LIMIT 20;
- 上一篇: 刘心向学(8)指针数组的应用
- 下一篇: 文档在线预览(四) 总结篇
猜你喜欢
- 2025-01-14 手机帝国存档怎么修改 存档简单修改教程
- 2025-01-14 文档在线预览(四) 总结篇
- 2025-01-14 刘心向学(8)指针数组的应用
- 2025-01-14 C#控件美化之路(11):控件ListBox增加DataTable数据绑定功能
- 2025-01-14 一文看懂MySQL如何判断InnoDB表是独立表空间还是共享表空间
- 2025-01-14 SpringBoot实现MySQL数据库自动备份管理系统
- 2025-01-14 一键生成数据库文档,从此告别人工整理文档
- 2025-01-14 all about visitor management system you need to know 03
- 2025-01-14 一篇文章教会你进行Mysql数据库和数据表的基本操作
- 2025-01-14 C#中FastReport报表的使用总结
- 01-14手机帝国存档怎么修改 存档简单修改教程
- 01-14文档在线预览(四) 总结篇
- 01-14MySQL数据库表碎片收集整理那些事
- 01-14刘心向学(8)指针数组的应用
- 01-14C#控件美化之路(11):控件ListBox增加DataTable数据绑定功能
- 01-14一文看懂MySQL如何判断InnoDB表是独立表空间还是共享表空间
- 01-14SpringBoot实现MySQL数据库自动备份管理系统
- 01-14一键生成数据库文档,从此告别人工整理文档
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)