mysql进阶-重构表

目录

1. 原因

2. 如何重构表呢?

2.1 命令1:

2.2 命令2:

2.3 命令3:


1. 原因

正常的业务开发,为什么需要重构表呢?

原因1:某张表存在大量的新增和删除操作,导致表经历过大量的页分裂。

原因2:innodb的统计信息不准确。统计信息可以通过如下sql进行查看:

SHOW INDEX FROM <table> WHERE Key_name = '索引名称';

查询结果展示如下:

其中,红色的字段含义是基数,也就是该表中存在多少个不同的数。当表中的数据越来越大的时候,这个字段的值偏差可能会比较大,这是由innodb存储引擎的统计方法所造成。

2. 如何重构表呢?

主要涉及到如下三个命令:

2.1 命令1:alter table

alter table <表名> engine = InnoDB;

该命令会对表进行重建,重建之后,数据就会变得更紧凑,数据占用文件大小会更小。

2.2 命令2:analyze table

analyze table <表名>;

该命令只会对索引信息做统计,可以解决一些优化器选错索引的情况。

2.3 命令3:optimize table

optimize table <表名>;

该命令相当于重建表 + 重新对索引统计信息。

具体使用哪种命令可以根据具体的业务场景进行处理,本文分析至此。

相关推荐

  1. MySQL的增删改查(

    2024-01-12 15:54:03       27 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-12 15:54:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-12 15:54:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-12 15:54:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-12 15:54:03       18 阅读

热门阅读

  1. 力扣(leetcode)第541题反转字符串II(Python)

    2024-01-12 15:54:03       35 阅读
  2. [BUG] docker: unknown server OS: .

    2024-01-12 15:54:03       31 阅读
  3. 力扣labuladong一刷day59天动态规划

    2024-01-12 15:54:03       25 阅读
  4. SpringSecurity入门demo(四)授权

    2024-01-12 15:54:03       37 阅读
  5. AttributeError: ‘str‘ object has no attribute ‘spilt‘

    2024-01-12 15:54:03       26 阅读
  6. 实名核验、企业工商、生活常用等API分享

    2024-01-12 15:54:03       31 阅读
  7. 代码随想录 字符串

    2024-01-12 15:54:03       39 阅读