Mysql 查询数据库容量大小的方法步骤
方法如下:
?1 2 3 4 5 6 7 8 | mysql> use information_schema; mysql> select concat(round( sum (DATA_LENGTH/1024/1024),2), 'MB' ) as data from TABLES; + -----------+ | data | + -----------+ | 3052.76MB | + -----------+ 1 row in set (0.02 sec) |
统计一下所有库数据量
每张表数据量=AVG_ROW_LENGTH*TABLE_ROWS+INDEX_LENGTH
?1 2 3 | SELECT SUM (AVG_ROW_LENGTH*TABLE_ROWS+INDEX_LENGTH)/1024/1024 AS total_mb FROM information_schema.TABLES |
统计每个库大小:
?1 2 3 | SELECT table_schema, SUM (AVG_ROW_LENGTH*TABLE_ROWS+INDEX_LENGTH)/1024/1024 AS total_mb FROM information_schema.TABLES group by table_schema; |
第二种情况:查看指定数据库的大小,比如说:数据库test,方法如下:
?1 2 3 4 5 6 7 8 | mysql> use information_schema; mysql> select concat(round( sum (DATA_LENGTH/1024/1024),2), 'MB' ) as data from TABLES where table_schema= 'test' ; + ----------+ | data | + ----------+ | 142.84MB | + ----------+ 1 row in set (0.00 sec) |
1.查看所有数据库各容量大小
?1 2 3 4 5 6 7 8 | 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.查看所有数据库各表容量大小
?1 2 3 4 5 6 7 8 | 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.查看指定数据库容量大小
?1 2 3 4 5 6 7 8 | 例:查看mysql库容量大小 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 where table_schema= 'mysql' ; |
4.查看指定数据库各表容量大小
?1 2 3 4 5 6 7 8 9 10 11 | 例:查看mysql库各表容量大小 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 where table_schema= 'mysql' order by data_length desc , index_length desc ; |
题外方法
直接用shell命令统计mysql data目录中的大小(注意只有库,不包含数据库日志大小)
备注 :
data_length :存储数据大小
data_length/1024/1024:将字节转换为MB
round(sum(data_length/1024/1024),2):取两位小数
concat(round(sum(data_length/1024/1024),2),'MB') :给计算结果追加单位 “MB”
到此这篇关于Mysql 查询数据库容量大小的方法步骤的文章就介绍到这了,更多相关Mysql 查询数据库容量大小内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://segmentfault.com/a/1190000022874702
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。