MySQL数据库实现统计所有表的空间占用与行数

 更新时间:2026年02月09日 09:00:10   作者:清山博客  
这篇文章主要为大家详细介绍了MySQL数据库实现统计所有表的空间占用与行数的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下

查看某个数据库中所有表的空间与行数统计

SELECT 
    TABLE_NAME AS `表名`,
    TABLE_ROWS AS `行数`,
    ROUND(DATA_LENGTH / 1024 / 1024, 2) AS `数据大小(MB)`,
    ROUND(INDEX_LENGTH / 1024 / 1024, 2) AS `索引大小(MB)`,
    ROUND((DATA_LENGTH + INDEX_LENGTH) / 1024 / 1024, 2) AS `总占用空间(MB)`,
    ROUND((DATA_LENGTH + INDEX_LENGTH) / 1024 / 1024 / 1024, 2) AS `总占用空间(GB)`
FROM 
    information_schema.TABLES
WHERE 
    TABLE_SCHEMA = 'your_database_name' -- 替换为你的数据库名
ORDER BY 
    (DATA_LENGTH + INDEX_LENGTH) DESC;

执行结果

查看某个数据库总空间占用情况

SELECT 
    TABLE_SCHEMA AS `数据库名`,
    SUM(TABLE_ROWS) AS `总行数`,
    ROUND(SUM(DATA_LENGTH) / 1024 / 1024, 2) AS `数据总大小(MB)`,
    ROUND(SUM(INDEX_LENGTH) / 1024 / 1024, 2) AS `索引总大小(MB)`,
    ROUND(SUM(DATA_LENGTH + INDEX_LENGTH) / 1024 / 1024, 2) AS `总占用空间(MB)`,
    ROUND(SUM(DATA_LENGTH + INDEX_LENGTH) / 1024 / 1024 / 1024, 2) AS `总占用空间(GB)`
FROM 
    information_schema.TABLES
WHERE 
    TABLE_SCHEMA = 'your_database_name'
GROUP BY 
    TABLE_SCHEMA;

执行结果

知识扩展

统计数据库下所有表的数据行数

刚开始统计数据库中有多少行数据的时候,使用 information_schema.TABLES 去统计发现误差很大 ,具体原因这里不再说明

select
table_schema as '数据库',
table_name as '表名',
table_comment 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='test'
order by table_rows desc, index_length desc;

以下是另一个方法:

执行sql,生成所有表的统计语句

select concat(
'select "',
TABLE_name,
'", count(*) as t from `',
TABLE_SCHEMA,
'`.`',
TABLE_name,
'` union all'
) from information_schema.tables

-- 排除指定库
where
 table_schema not in('mysql','information_schema','performance_schema','sys');

结果如下:

查询出来的结果拷贝出来,去掉最后一行的 union all

汇总

到此这篇关于MySQL数据库实现统计所有表的空间占用与行数的文章就介绍到这了,更多相关MySQL统计表空间占用与行数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL使用TEXT/BLOB类型的知识点详解

    MySQL使用TEXT/BLOB类型的知识点详解

    在本篇文章里小编给大家整理的是关于MySQL使用TEXT/BLOB类型的几点注意内容,有兴趣的朋友们学习下。
    2020-03-03
  • SQL中CAST()实例之转换数据类型

    SQL中CAST()实例之转换数据类型

    CAST函数用于将某种数据类型的表达式显式转换为另一种数据类型,下面这篇文章主要给大家介绍了关于SQL中CAST()实例之转换数据类型的相关资料,需要的朋友可以参考下
    2023-01-01
  • MySQL数据库SSL安全连接方式

    MySQL数据库SSL安全连接方式

    本文主要介绍了MySQL 8.0.43的SSL配置和使用方法,包括SSL证书的创建、SSL连接的配置、SSL用户的安全设置以及SSL登录的实现,SSL可以确保数据在传输过程中的机密性、完整性和身份验证,从而提高数据库的安全性
    2025-11-11
  • 解决Java程序使用MySQL时返回参数为乱码的示例教程

    解决Java程序使用MySQL时返回参数为乱码的示例教程

    这篇文章主要介绍了解决Java程序使用MySQL返回参数为乱码的问题的教程,通过示例来讲解utf-8编码在MySQL中的相关配置,示例需要的朋友可以参考下
    2015-12-12
  • 深入理解Mysql事务隔离级别与锁机制问题

    深入理解Mysql事务隔离级别与锁机制问题

    MySQL默认的事务隔离级别是可重复读,用Spring开发程序时,如果不设置隔离级别默认用MySQL设置的隔离级别,如果Spring设置了就用已设置的隔离级别,本文重点给大家介绍Mysql事务隔离级别与锁机制的相关知识,一起看看吧
    2021-09-09
  • MySQL中Buffer Pool内存结构详情

    MySQL中Buffer Pool内存结构详情

    这篇文章主要介绍了MySQL中Buffer Pool内存结构详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • MySQL系列之四 SQL语法

    MySQL系列之四 SQL语法

    SQL是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统,这篇文章主要给大家介绍了SQL语法的相关资料,需要的朋友可以参考下
    2021-07-07
  • 如何合理使用数据库冗余字段的方法

    如何合理使用数据库冗余字段的方法

    今天小编就为大家分享一篇关于如何合理使用数据库冗余字段的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • mysql多条数据合并成一条的3种常见方法

    mysql多条数据合并成一条的3种常见方法

    在实际的应用开发中,有时我们需要将多条数据合并成一条数据,以便更好地进行数据分析和处理,本文就来介绍一下mysql多条数据合并成一条的方法,具有一定的参考价值
    2023-10-10

最新评论