mysql查看数据库表大小、索引大小与表数量
假定要查的数据库名称是“xxxx_mall”
1、查看数据库数据占用大小
select concat(round(sum(DATA_LENGTH/1024/1024),2),'MB') as data from information_schema.TABLES where table_schema='xxxx_mall'
2、查看数据库索引占用大小
select concat(round(sum(INDEX_LENGTH/1024/1024),2),'MB') as data from information_schema.TABLES where table_schema='xxxx_mall'
3、查看数据库各个表的行数,索引大小,数据大小
select table_name,table_rows,concat(round((index_length)/1024/1024,2),'MB') index_data ,concat(round((data_length)/1024/1024,2),'MB') data_data
from information_schema.TABLES where table_schema='xxxx_mall'
4、查看各个数据库的表个数
select count(*) tables, table_schema from information_schema.tables group by table_schema
5、查看某个数据库的表及描述列表
select (@i :=@i + 1) AS '序号', table_name AS '表名' ,table_comment AS '表说明'from information_schema.tables,(SELECT @i := 0) AS inum where table_schema = 'XXXXX_DB'
6、mysql统计指定数据库的各表的条数
SELECT table_schema,table_name,table_rows,CREATE_TIME FROM TABLES WHERE TABLE_SCHEMA='cloud_**' ORDER BY table_rows DESC;
SELECT table_schema,table_name,table_rows,CREATE_TIME FROM TABLES WHERE TABLE_SCHEMA='db_name_xxxx' and table_name like 'tabe_name%' ORDER BY table_name DESC;备注:
(1)mysql会定期自动做统计信息的收集,每天一次,由参数
information_schema_stats_expiry
控制,参数 information_schema_stats_expiry 的值决定再次收集表的统计信息的时间间隔,默认 86400 秒。如果设置为 0 ,则表示实时更新统计信息,当然势必会影响一部分性能。 (2)想要精准一些,在统计前,做一下analyze table table_name;但是遇到超级大表,手工做一个analyze可能会卡很长时间。
当MySQL数据库做FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE, or OPTIMIZE TABLE这些操作时,会导致需要关闭内存中的表,并重新打开表,加载新的表结构到内存中。但是关闭表,需要等待所有的在这个表上的操作执行结束(包括select,insert,update,lock table等),所以当有一个特别慢的select一直在执行时,analyze table命令就一直无法结束。
若遇到这种情况,需要定位哪个慢sql导致的,并且kill掉才行。查询语句 : select * from processlist where info like ‘%表名%’ and time>=(select time from processlist where id=‘analyze操作的进程号’) order by time desc;
因此,生产库上执行analyze table建议:
(a)、执行之前,先估算一下表的数据量,根据经验预估需要消耗的时间,同时查看是否有采集信息表的慢SQL,大事务在执行。
(b)、避免在业务高峰期执行analyze table进行统计信息采集。
(a)、执行之前,先估算一下表的数据量,根据经验预估需要消耗的时间,同时查看是否有采集信息表的慢SQL,大事务在执行。
(b)、避免在业务高峰期执行analyze table进行统计信息采集。
相关文章:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)