2011-02-16 55 views

回答

8

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; 
1

嘗試尋找在給定的信息由

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

+0

謝謝,Data_length是以字節爲單位嗎? – Cory 2011-02-16 02:14:43

+0

@Cory:我相信如此。 – Orbling 2011-02-16 02:18:08

+0

是的,它是以字節爲單位的。但是index_length也很重要,因爲它可以與data_length一樣多或更多。 – 2011-09-18 17:59:34

2

如果您正在尋找實際的磁盤空間使用情況怎麼樣只需使用像「du」這樣的文件系統工具來計算mysql數據目錄的大小?