如何找出MySQL数据库中数据的总大小?
答
这link有相当激烈的查询......这会给你更多的比你需要...:
SELECT s.schema_name,
CONCAT(IFNULL(ROUND((SUM(t.data_length)+SUM(t.index_length)) /1024/1024,2),0.00)) total_size_in_MB,
CONCAT(IFNULL(ROUND(((SUM(t.data_length)+SUM(t.index_length))-SUM(t.data_free))/1024/1024,2),0.00)) data_used_IN_MB,
CONCAT(IFNULL(ROUND(SUM(data_free)/1024/1024,2),0.00)) data_free_IN_MB,
IFNULL(ROUND((((SUM(t.data_length)+SUM(t.index_length))-SUM(t.data_free))/((SUM(t.data_length)+SUM(t.index_length)))*100),2),0) pct_used,
COUNT(table_name) total_tables
FROM INFORMATION_SCHEMA.SCHEMATA s
LEFT JOIN INFORMATION_SCHEMA.TABLES t ON s.schema_name = t.table_schema
WHERE s.schema_name = 'abc' -- give your schema name
GROUP BY s.schema_name
ORDER BY pct_used DESC;
答
尝试寻找在给定的信息由
SHOW TABLE STATUS FROM dbname;
的Data_length
列应该会感兴趣。
参见:http://dev.mysql.com/doc/refman/5.1/en/show-table-status.html
,或者您需要一个正常的查询的范围内进行访问,那么INFORMATION_SCHEMA.TABLES
表的内容可以提供帮助。 (参见:http://dev.mysql.com/doc/refman/5.1/en/tables-table.html)
答
如果您正在寻找实际的磁盘空间使用情况怎么样只需使用像“du”这样的文件系统工具来计算mysql数据目录的大小?
谢谢,Data_length是以字节为单位吗? – Cory 2011-02-16 02:14:43
@Cory:我相信如此。 – Orbling 2011-02-16 02:18:08
是的,它是以字节为单位的。但是index_length也很重要,因为它可以与data_length一样多或更多。 – 2011-09-18 17:59:34