MySQL如何查看某个表所占空间大小

 更新时间:2025年05月16日 09:06:40   作者:数据知道  
在MySQL数据库管理和优化中,了解表所占用的空间大小是非常重要的,本文为大家整理了多种查看MySQL表空间大小的方法,需要的可以参考一下

一、使用SQL查询查看表空间

1.1 查询所有表的大小(包括数据和索引)

SELECT 
    table_schema AS '数据库名',
    table_name 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)',
    table_rows AS '行数'
FROM 
    information_schema.TABLES 
WHERE 
    table_schema NOT IN ('information_schema', 'mysql', 'performance_schema')
ORDER BY 
    (data_length + index_length) DESC;
SELECT 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)'
FROM information_schema.TABLES 
where table_name = '表名';

1.2 查询特定数据库的表大小

SELECT 
    table_name 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)',
    table_rows AS '行数'
FROM 
    information_schema.TABLES 
WHERE 
    table_schema = '你的数据库名'
ORDER BY 
    (data_length + index_length) DESC;

1.3 查询单个表的详细空间信息

SELECT 
    table_name AS '表名',
    engine 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_free/1024/1024, 2) AS '碎片空间(MB)',
    table_rows AS '行数',
    avg_row_length AS '平均行长度(字节)',
    create_time AS '创建时间',
    update_time AS '更新时间'
FROM 
    information_schema.TABLES 
WHERE 
    table_schema = '你的数据库名'
    AND table_name = '你的表名';

二、使用命令行工具查看表空间

2.1 使用mysql客户端查询

mysql -u用户名 -p密码 -e "SELECT table_name 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)' \
FROM information_schema.TABLES \
WHERE table_schema='你的数据库名' \
ORDER BY (data_length+index_length) DESC;"

2.2 查看物理文件大小(适用于MyISAM/InnoDB)

# 切换到MySQL数据目录
cd /var/lib/mysql/你的数据库名/

# 查看文件大小
ls -lh *.ibd *.frm *.MYD *.MYI

# 计算总大小
du -sh ./*

三、查看InnoDB表的空间使用详情

3.1 查看InnoDB表空间状态

SHOW TABLE STATUS FROM 你的数据库名 LIKE '你的表名'\G

3.2 查看InnoDB引擎状态(包含缓冲池等信息)

SHOW ENGINE INNODB STATUS\G

3.3 查询InnoDB表空间文件信息

SELECT 
    FILE_NAME, 
    TABLESPACE_NAME, 
    ENGINE, 
    TOTAL_EXTENTS, 
    EXTENT_SIZE, 
    INITIAL_SIZE, 
    MAXIMUM_SIZE 
FROM 
    INFORMATION_SCHEMA.FILES 
WHERE 
    FILE_TYPE = 'DATAFILE';

四、高级空间分析工具

4.1 使用pt-diskstats(Percona工具包)

pt-diskstats --devices=/var/lib/mysql

4.2 使用pt-mysql-summary(Percona工具包)

pt-mysql-summary --user=用户名 --password=密码

4.3 使用mysqldumpslow分析表空间增长

mysqldumpslow -s t /var/log/mysql/mysql-slow.log

五、空间优化相关查询

5.1 查找碎片化严重的表

SELECT 
    table_schema AS '数据库',
    table_name AS '表名',
    ROUND(data_free/1024/1024, 2) AS '碎片空间(MB)',
    ROUND((data_length + index_length)/1024/1024, 2) AS '总大小(MB)',
    ROUND((data_free/(data_length + index_length + data_free))*100, 2) AS '碎片率(%)'
FROM 
    information_schema.TABLES 
WHERE 
    table_schema NOT IN ('information_schema', 'mysql', 'performance_schema')
    AND data_free > 0
ORDER BY 
    data_free DESC
LIMIT 10;

5.2 查看表空间自动扩展设置

SELECT 
    table_name, 
    engine, 
    row_format, 
    create_options 
FROM 
    information_schema.TABLES 
WHERE 
    table_schema = '你的数据库名';

六、注意事项

权限要求:查询information_schema需要相应的权限

数据准确性:table_rows是估算值,特别是对于InnoDB表

存储引擎差异:

• InnoDB表数据存储在.ibd文件中(独立表空间)或共享表空间中

• MyISAM表数据存储在.MYD文件中,索引存储在.MYI文件中

临时表空间:临时表和使用内存引擎的表不会显示在磁盘使用统计中

二进制日志和事务日志:这些日志文件占用空间但不包含在表空间统计中

七、自动化监控脚本示例

#!/bin/bash

# MySQL表空间监控脚本
DB_USER="用户名"
DB_PASS="密码"
DB_NAME="数据库名"
OUTPUT_FILE="/tmp/mysql_table_sizes_$(date +%Y%m%d).csv"

echo "表名,数据大小(MB),索引大小(MB),总大小(MB),行数,碎片空间(MB)" > $OUTPUT_FILE

mysql -u$DB_USER -p$DB_PASS -e "SELECT \
    CONCAT(table_name, ',', \
    ROUND(data_length/1024/1024, 2), ',', \
    ROUND(index_length/1024/1024, 2), ',', \
    ROUND((data_length + index_length)/1024/1024, 2), ',', \
    table_rows, ',', \
    ROUND(data_free/1024/1024, 2)) \
FROM information_schema.TABLES \
WHERE table_schema = '$DB_NAME' \
ORDER BY (data_length + index_length) DESC;" >> $OUTPUT_FILE

​​​​​​​echo "报告已生成: $OUTPUT_FILE"

通过以上方法,您可以全面了解MySQL数据库中各个表的空间占用情况,为数据库优化和维护提供数据支持。

到此这篇关于MySQL如何查看某个表所占空间大小的文章就介绍到这了,更多相关MySQL查看表空间大小内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 一文深入理解MySQL中的UTF-8与UTF-8MB4字符集

    一文深入理解MySQL中的UTF-8与UTF-8MB4字符集

    在全球化的今天,数据的存储与处理需要支持多种语言与字符集,对于 Web 应用程序和数据库系统来说,字符集的选择尤为重要,特别是在处理包含多种语言字符(如中文、阿拉伯文、表情符号等)的系统中,本文将深入探讨 MySQL 中的两个常见字符集:UTF-8 和 UTF-8MB4
    2024-11-11
  • mysql中mysql-bin.000001是什么文件可以删除吗

    mysql中mysql-bin.000001是什么文件可以删除吗

    这篇文章主要介绍了mysql中mysql-bin.000001是什么文件可以删除吗,需要的朋友可以参考下
    2019-05-05
  • MySQL开启Slow慢查询的方法示例

    MySQL开启Slow慢查询的方法示例

    这篇文章主要给大家介绍了关于MySQL开启Slow慢查询的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-02-02
  • MySQL解决Navicat设置默认字符串时的报错问题

    MySQL解决Navicat设置默认字符串时的报错问题

    本文主要介绍了MySQL解决Navicat设置默认字符串时的报错,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • MySQL的cpu使用率100%的问题排查流程

    MySQL的cpu使用率100%的问题排查流程

    线上mysql服务器经常性出现cpu使用率100%的告警, 因此本文整理一下排查该问题的常规流程,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2025-02-02
  • 查看连接mysql的IP地址的实例方法

    查看连接mysql的IP地址的实例方法

    在本篇文章里小编给大家分享的是一篇关于查看连接mysql的IP地址的实例方法,有需要的朋友们可以参考下。
    2020-10-10
  • 总结MySQL修改最大连接数的两个方式

    总结MySQL修改最大连接数的两个方式

    最大连接数是可以通过mysql进行修改的,mysql数据库修改最大连接数常用有两种方法,今天我们分析一下这两种方法之间的特点和区别,以便我们能更好的去维护mysql。下面我们来看一下mysql修改最大连接数的方法,希望文章能够帮助到各位朋友。
    2016-08-08
  • mysql中的临时表如何使用

    mysql中的临时表如何使用

    这篇文章主要介绍了mysql中的临时表如何使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • MySQL 8中新增的这三大索引 隐藏、降序、函数

    MySQL 8中新增的这三大索引 隐藏、降序、函数

    这篇文章主要介绍了MySQL 8.x版本中新增的三大索引 隐藏索引、降索引序、函数索引,如果文章对你有点帮助,小伙伴们点赞、收藏、评论、分享走起呀
    2021-09-09
  • Mysql事务隔离级别原理实例解析

    Mysql事务隔离级别原理实例解析

    这篇文章主要介绍了Mysql事务隔离级别原理实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03

最新评论