MySQL 查询数据库的数据总量

需求:查看MySQL数据库的数据总量,以MB为单位展示数据库占用的磁盘空间

实践:

  1. 登录到MySQL数据库服务器

  2. 选择你想要查看数据总量的数据库

    sql 复制代码
    USE shield;
  3. 运行查询以获取数据库的总大小

    sql 复制代码
    SELECT 
      table_schema AS 'Database',
      ROUND(SUM(data_length + index_length) / 1024 / 1024, 2) AS 'Size in MB'
    FROM information_schema.TABLES 
    WHERE table_schema = 'shield'
    GROUP BY table_schema;

这个查询将返回数据库的名称和大小(以MB为单位)。这里,data_length 是表数据的大小,index_length 是索引的大小。我们将这两个值相加,然后除以1024两次(因为1MB = 1024KB,1KB = 1024字节)来转换为MB。

详细步骤解释:

  • table_schema:数据库名称。
  • data_length:表中数据的大小。
  • index_length:表索引的大小。
  • SUM(data_length + index_length):计算所有表的数据和索引总大小。
  • ROUND(..., 2):将结果四舍五入到小数点后两位。

示例:

假设你的数据库名称是 shield,运行以下查询:

sql 复制代码
SELECT 
  table_schema AS 'Database',
  ROUND(SUM(data_length + index_length) / 1024 / 1024, 2) AS 'Size in MB'
FROM information_schema.TABLES 
WHERE table_schema = 'shield'
GROUP BY table_schema;

这将返回类似于以下结果:

复制代码
+------------+-----------+
| Database   | Size in MB|
+------------+-----------+
| shield     |   6.66    |
+------------+-----------+

顺便看一下备份之后的大小

注意事项:

  • 这个查询返回的是近似值,因为MySQL在计算表大小时可能会有一些差异。
  • 如果你的数据库非常大,运行这个查询可能会消耗一些资源,因为它需要扫描所有的表。
相关推荐
小陈工3 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
0xDevNull7 小时前
MySQL数据冷热分离详解
后端·mysql
科技小花7 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸7 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain7 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希8 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神8 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员8 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java8 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿9 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb