更新时间:2022-03-23 GMT+08:00
分享

表维护

操作场景

随着业务工作增加,表将变得较为繁冗,插入、更新或者删除等操作时,会占用一定的空间,造成浪费降低性能。定期进行表维护操作,可改善数据库性能。

功能详情

  • 优化表

    数据库使用OPTIMIZE TABLE语句优化表,可重新利用表中的空间,整理文件碎片等,以便以后再利用。

    优化过程中,会对表添加只读锁,因而建议在业务低谷期间进行优化操作。

  • 检查表

    数据库使用CHECK TABLE语句来检查表,可检查出表是否存在错误。检查表提供常规、快速、快、已改变和扩展检查5种方式。

    • 常规:扫描行,以验证被删除的链接是有效的。也可以计算各行的关键字校验和,并使用计算出的校验和验证这一点。
    • 快:不扫描行,不检查错误的链接。
    • 快速:只检查没有被正确关闭的表。
    • 已改变:只检查上次检查后被更改的表,和没有被正确关闭的表。
    • 扩展:对每行的所有关键字进行一个全面的关键字查找。

      CHECK TABLE语句在执行过程中会给表加上只读锁。

  • 修复表

    数据库使用REPAIR TABLE语句来修复损坏的或错误的表。修复表提供常规、快速、扩展3种方式。

    • 常规:不加任何参数;即repaire table 表名,表示简单修复数据文件和索引文件。
    • 快速:加上quick参数,即repaire table 表名 quick,表示最快的修复,只修复索引文件,不修复数据文件。
    • 扩展:加上extended参数,即repaire table 表名 extend,表示最慢的修复,修改数据文件和索引文件,试图从数据文件恢复每一行,需要逐行重建索引。
  • 分析表

    使用ANALYZE TABLE语句来分析表,在执行过程中数据库系统会对表添加只读锁。分析期间,只能读取表中的记录,不能进行更新和插入操作。

    MySQL在表优化过程中会产生临时文件,该临时文件可能会占用相当于当前表数据两倍的磁盘空间。

操作步骤

“检查表”“修复表”、2种类别的表维护操作类似,以下以检查表操作为例进行描述。

  1. 在顶部导航栏选择“库管理”,在对象列表页签左侧菜单栏选择“表”
  2. 在列表右侧操作栏选择“更多”>“表维护”

    图1 表维护

  3. 在优化表弹出框中,单击“确定”,执行表优化操作。

    图2 优化表

分享:

    相关文档

    相关产品

close