mysql笔记

引用地址

  • 查看所有数据库容量大小
select 
table_schema as '数据库',
sum(table_rows) as '记录数',
sum(truncate(data_length/1024/1024, 2)) as '数据容量(MB)',
sum(truncate(index_length/1024/1024, 2)) as '索引容量(MB)'
from information_schema.tables
group by table_schema
order by sum(data_length) desc, sum(index_length) desc;

  • 查看数据库各表容量大小
select 
table_schema as '数据库',
table_name as '表名',
table_rows as '记录数',
truncate(data_length/1024/1024, 2) as '数据容量(MB)',
truncate(index_length/1024/1024, 2) as '索引容量(MB)'
from information_schema.tables
order by data_length desc, index_length desc;

  • 查看指定数据库容量大小
select 
table_schema as '数据库',
sum(table_rows) as '记录数',
sum(truncate(data_length/1024/1024, 2)) as '数据容量(MB)',
sum(truncate(index_length/1024/1024, 2)) as '索引容量(MB)'
from information_schema.tables
where table_schema='mysql';

  • 查看指定数据库各表容量大小
select 
table_schema as '数据库',
table_name 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='mysql'
order by data_length desc, index_length desc;

  • 查看锁表及delete大容量表后整理数据空间
#查看当前锁定表的状态,其中 In_use 表示表当前是否被锁定。如果 In_use 的值大于 0,说明该表被锁定了
SHOW OPEN TABLES WHERE In_use >0;
#这个命令可以显示当前 MySQL 数据库的所有进程以及它们的状态。如果一个表被锁定了,会有一个Waiting for table metadata
SHOW FULL PROCESSLIST;
#使用第二个命令查看当前的锁定信息后,可以看到该表被哪些进程锁定了。使用上面的命令可以杀掉当前锁定该表的进程
KILL ***;
#释放表锁
UNLOCK TABLES;
#使用OPTIMIZE TABLE可以执行以下操作:
#重建表的数据文件
#减少碎片,使数据存储更加紧凑
#可能会回收未使用的空间,并将其返还给操作系统
#对于InnoDB表,执行OPTIMIZE TABLE通常会重新构建表,以减少页面的碎片和压缩数据页
OPTIMIZE TABLE table_name