MySQL如何查看某个表所占空间大小?(表空间大小查看方法)

news2025/5/19 10:23:09

文章目录

    • 一、使用SQL查询查看表空间
      • 1.1 查询所有表的大小(包括数据和索引)
      • 1.2 查询特定数据库的表大小
      • 1.3 查询单个表的详细空间信息
    • 二、使用命令行工具查看表空间
      • 2.1 使用`mysql`客户端查询
      • 2.2 查看物理文件大小(适用于MyISAM/InnoDB)
    • 三、查看InnoDB表的空间使用详情
      • 3.1 查看InnoDB表空间状态
      • 3.2 查看InnoDB引擎状态(包含缓冲池等信息)
      • 3.3 查询InnoDB表空间文件信息
    • 四、高级空间分析工具
      • 4.1 使用`pt-diskstats`(Percona工具包)
      • 4.2 使用`pt-mysql-summary`(Percona工具包)
      • 4.3 使用`mysqldumpslow`分析表空间增长
    • 五、空间优化相关查询
      • 5.1 查找碎片化严重的表
      • 5.2 查看表空间自动扩展设置
    • 六、注意事项
    • 七、自动化监控脚本示例

在MySQL数据库管理和优化中,了解表所占用的空间大小是非常重要的。以下是多种查看MySQL表空间大小的方法,包括SQL查询、命令行工具和可视化工具。

一、使用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 = '你的数据库名';

六、注意事项

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

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

  3. 存储引擎差异:
    • InnoDB表数据存储在.ibd文件中(独立表空间)或共享表空间中
    • MyISAM表数据存储在.MYD文件中,索引存储在.MYI文件中

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

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

七、自动化监控脚本示例

#!/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数据库中各个表的空间占用情况,为数据库优化和维护提供数据支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2379208.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

低延迟与高性能的技术优势解析:SmartPlayer VS VLC Media Player

在实时视频流的应用中,RTSP(Real-Time Streaming Protocol)播放器扮演着至关重要的角色,尤其是在视频监控、远程医疗、直播等高实时性需求的场景中。随着行业需求的不断升级,对播放器的低延迟、稳定性、兼容性等方面的…

【交互 / 差分约束】

题目 代码 #include <bits/stdc.h> using namespace std; using ll long long;const int N 10510; const int M 200 * 500 10; int h[N], ne[M], e[M], w[M], idx; ll d[N]; int n, m; bool st[N]; int cnt[N];void add(int a, int b, int c) {w[idx] c, e[idx] b…

宝塔面板部署前后端项目SpringBoot+Vue2

这篇博客主要用来记录宝塔部署前端后端项目的过程。因为宝塔部署有点麻烦&#xff0c;至少在我看来挺麻烦的。我还是喜欢原始的ssh连接服务器进行操作。但是公司有项目用到了宝塔&#xff0c;没办法啊&#xff0c;只能摸索记录一下。 我们需要提前准备好后端项目的jar包和前端项…

现代生活健康养生新视角

在科技飞速发展的今天&#xff0c;我们的生活方式发生巨大转变&#xff0c;健康养生也需要新视角。从光线、声音等生活细节入手&#xff0c;能为健康管理开辟新路径。​ 光线与健康密切相关。早晨接触自然光线&#xff0c;可调节生物钟&#xff0c;提升血清素水平&#xff0c;…

多模态大语言模型arxiv论文略读(八十一)

What is the Visual Cognition Gap between Humans and Multimodal LLMs? ➡️ 论文标题&#xff1a;What is the Visual Cognition Gap between Humans and Multimodal LLMs? ➡️ 论文作者&#xff1a;Xu Cao, Bolin Lai, Wenqian Ye, Yunsheng Ma, Joerg Heintz, Jintai …

3.4/Q2,Charls最新文章解读

文章题目&#xff1a;Associations between reversible and potentially reversible cognitive frailty and falls in community-dwelling older adults in China: a longitudinal study DOI&#xff1a;10.1186/s12877-025-05872-2 中文标题&#xff1a;中国社区老年人可逆性和…

通过觅思文档项目实现Obsidian文章浏览器在线访问

觅思文档项目开源地址 觅思文档项目开源地址&#xff1a;https://gitee.com/zmister/MrDoc 觅思文档部署步骤概览 服务器拉取代码&#xff1a; git clone https://gitee.com/zmister/mrdoc-install.git && cd mrdoc-install && chmod x docker-install.sh &a…

5月18总结

一.算法题总结 1. 解题思路&#xff1a;对于这个题&#xff0c;我最开始想到就是二分&#xff0c;但是头痛的是有三个解&#xff0c;如果我在-100到100之间二分&#xff0c;那么只能得出一个解&#xff0c;然后我就想了一下&#xff0c;这个要求精度&#xff0c;那么0.01这么小…

Linux Bash | Capture Output / Recall

注&#xff1a;本文为 “Linux Bash | Capture Output / Recall” 相关文章合辑。 英文引文&#xff0c;机翻未校。 中文引文&#xff0c;略作重排。 Automatically Capture Output of the Last Command Into a Variable Using Bash 使用 Bash自动将最后一个命令的输出捕获到…

2025/5/18

继续研究一下大佬的RAG项目。开始我的碎碎念。 RAG可以分成两部分&#xff1a;一个是问答&#xff0c;一个是数据处理。 问答是人提问&#xff0c;然后查数据库&#xff0c;把查的东西用大模型组织成人话&#xff0c;回答人的提问。 数据处理是把当下知识库里的东西&#xf…

基于Quicker构建从截图到公网图像链接获取的自动化流程

写在前面&#xff1a;本博客仅作记录学习之用&#xff0c;部分图片来自网络&#xff0c;如需引用请注明出处&#xff0c;同时如有侵犯您的权益&#xff0c;请联系删除&#xff01; 文章目录 前言预备内容转webp程序PicGo设置Quicker设置视频演示总结互动致谢参考 前言 在自建博…

LeetCode算 法 实 战 - - - 双 指 针 与 移 除 元 素、快 慢 指 针 与 删 除 有 序 数 组 中 的 重 复 项

LeetCode算 法 实 战 - - - 双 指 针 与 移 除 元 素、快 慢 指 针 与 删 除 有 序 数 组 中 的 重 复 项 第 一 题 - - - 移 除 元 素方 法 一 - - - 双 重 循 环方 法 二 - - - 双 指 针方 法 三 - - - 相 向 双 指 针&#xff08;面 对 面 移 动&#xff09; 第 二 题 - - -…

uniapp自定义日历计划写法(vue2)

文章目录 uniapp自定义日历计划写法(vue2)1、效果2、实现源码前言:我们有时候需要实现的日历找不到相应的插件的时候,往往需要手动去写一个日历,以下就是我遇到这样的问题时,手搓出来的一个解决方案,希望可以帮助到更多的人。创作不易,请多多支持uniapp自定义日历计划写…

Java IO框架

I/O框架 流 流的分类&#xff1a; 按方向&#xff1a; 输入流&#xff1a;将存储设备的内容读入到内存中 输出流&#xff1a;将内存的内容写入到存储设备中 按单位&#xff1a; 字节流&#xff1a;以字节为单位&#xff0c;可以读取所有数据 字符流&#xff1a;以字符为单…

数据库2——查询

查询 学习内容学习感受 学习内容 一、实验目的与要求&#xff1a; 1、掌握SQL单表及多表之间的查询 2、掌握统计及分组函数 二、实验内容&#xff1a; 1.简单查询 ① 从fruits表中检索s_id为100的供货商所供货的水果名和价格 源码&#xff1a; SELECT f_name, f_price FROM…

Android 性能优化入门(一)—— 数据结构优化

1、概述 一款 app 除了要有令人惊叹的功能和令人发指交互之外&#xff0c;在性能上也应该追求丝滑的要求&#xff0c;这样才能更好地提高用户体验&#xff1a; 优化目的性能指标优化的方向更快流畅性启动速度页面显示速度(显示和切换)响应速度更稳定稳定性避免出现 应用崩溃&…

数据库中的锁机制

目录 数据库中的锁机制:原理、分类与实际案例详解 一、数据库锁的核心作用与基本概念 1.1 为什么需要数据库锁? 1.2 锁的分类 二、锁机制的实现与典型场景 2.1 共享锁(Shared Lock) 工作原理 适用场景 代码示例(MySQL) 案例分析 2.2 排他锁(Exclusive Lock) …

【网络入侵检测】基于Suricata源码分析运行模式(Runmode)

【作者主页】只道当时是寻常 【专栏介绍】Suricata入侵检测。专注网络、主机安全&#xff0c;欢迎关注与评论。 1. 概要 &#x1f44b; 在 Suricata 中抽象出线程、线程模块和队列三个概念&#xff1a;线程类似进程&#xff0c;可多线程并行执行操作&#xff1b;监听、解码、检…

Linux常用命令(十四)

目录 vi编辑器命令 1-编辑模式 1&#xff09;准备一个txt文件并且进入vi 2&#xff09;按i进入编辑模式 3&#xff09;按o进入编辑模式 4&#xff09;按a进入编辑模式 ​ 2-底行模式 1&#xff09;退出vim 2&#xff09;撤销上次操作 3&#xff09;设置行号底行模式 4&#xff…

规则联动引擎GoRules初探

背景说明 嵌入式设备随着物联网在生活和生产中不断渗透而渐渐多起来&#xff0c;数据的采集、处理、分析在设备侧的自定义配置越来越重要。一个可通过图形化配置的数据处理过程&#xff0c;对于加速嵌入式设备的功能开发愈发重要。作为一个嵌入式软件从业者&#xff0c;笔者一…