MySQL 查看数据库和表空间大小及碎片处理

1. 查看所有数据库空间大小

  SELECT table_schema as '数据库',
		 sum(table_rows) as '记录数',
		 sum(truncate(data_length/1024/1024, 2)) as '数据容量(MB)',
		 sum(truncate(index_length/1024/1024, 2)) as '索引容量(MB)'
	FROM information_schema.tables
GROUP BY table_schema
ORDER BY sum(data_length) DESC, 
         sum(index_length) DESC;

2. 查看所有数据库中各个表的空间大小

  SELECT table_schema as '数据库',
         table_name as '表名',
         table_rows as '记录数',
         truncate(data_length/1024/1024, 2) as '数据容量(MB)',
         truncate(index_length/1024/1024, 2) as '索引容量(MB)'
    FROM information_schema.tables
ORDER BY data_length DESC, 
         index_length DESC;

3. 查看所有产生碎片的表

  SELECT table_schema db, 
         table_name, 
         data_free, 
         engine 
    FROM information_schema.tables 
   WHERE table_schema NOT IN ('information_schema', 'mysql') 
     AND data_free > 0 
ORDER BY DATA_FREE DESC;

4. 查看某个表的碎片大小

SHOW TABLE STATUS LIKE '表名';

  查询结果中的'Data_free'字段的值就是碎片大小。

5. 清理表碎片

/*1. MyISAM表*/

OPTIMIZE TABLE 表名

/*2. InnoDB表*/

ALTER TABLE 表名 engine = InnoDB

清除碎片操作会暂时锁表,数据量越大,耗费的时间越长,可以做个脚本,定期检查MySQL中 information_schema.tables字段,查看 data_free 字段,大于0话,就表示有碎片,当大于自己认为的警戒值的话,就清理一次。

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值