如何获取mysql数据库的大小? 假设目标数据库名为“v3”。


当前回答

或者,您可以直接跳转到数据目录并检查v3的组合大小。myd, v3。Myi和v3。FRM文件(用于myisam)或v3。Idb & v3.frm(用于innodb)。

其他回答

运行这个查询,你可能会得到你想要的:

SELECT table_schema "DB Name",
        ROUND(SUM(data_length + index_length) / 1024 / 1024, 1) "DB Size in MB" 
FROM information_schema.tables 
GROUP BY table_schema; 

这个查询来自mysql论坛,那里有更全面的说明可用。

mysqldiskusage  --server=root:MyPassword@localhost  pics

+----------+----------------+
| db_name  |         total  |
+----------+----------------+
| pics     | 1,179,131,029  |
+----------+----------------+

如果没有安装,可以通过安装mysql-utils包来安装,大多数主要发行版都应该打包这个包。

或者,您可以直接跳转到数据目录并检查v3的组合大小。myd, v3。Myi和v3。FRM文件(用于myisam)或v3。Idb & v3.frm(用于innodb)。

或者,如果使用phpMyAdmin,可以在数据库结构选项卡的页脚中查看表大小的总和。实际的数据库大小可能略大于这个大小,但它似乎与上面提到的table_schema方法一致。

的截图:

如果你想要排序所有数据库大小的列表,你可以使用:

SELECT * 
FROM   (SELECT table_schema AS `DB Name`, 
           ROUND(SUM(data_length + index_length) / 1024 / 1024, 1) AS `DB Size in MB`
        FROM   information_schema.tables 
        GROUP  BY `DB Name`) AS tmp_table 
ORDER  BY `DB Size in MB` DESC;