OPTIMIZE TABLE

功能描述

重建表和索引的物理空间,释放可回收空间给操作系统,并更新相关表的统计信息。

注意事项

  • 需要表vacuum/owner或superuser权限。
  • b数据库的optimize操作支持多表,openGauss的optimize操作只支持单表。
  • b数据库的optimize属于Online DDL操作,处理过程的主要阶段不影响表的读写;但openGauss的optimize会阻塞表的读写,表数据量较大时可能会存在长时间锁表情况,请谨慎操作。
  • optimize也会被其他事务或两阶段事务阻塞。
  • 尽量不要并发执行optimize多张表,如果需要并发执行,请降低并发数量,一般在3以下。
  • 执行optimize时需要确保数据目录当前剩余空间大于该表当前占用空间,不然可能会失败。
  • 表在短时间内删除大量数据后不要立即执行optimize,尝试等待几秒或执行若干其他事务后再执行,不然可能出现元组处于HEAPTUPLE_RECENTLY_DEAD状态无法正常回收的情况。

语法格式

  1. OPTIMIZE [VERBOSE] [NO_WRITE_TO_BINLOG | LOCAL] TABLE tbl_name

参数说明

  • [VERBOSE]

    1. 查看optimize处理详情,可缺省。
  • [NO_WRITE_TO_BINLOG | LOCAL]

    1. 仅兼容语法,无实际效果,可缺省。
  • tbl_name

    1. 表名,可指定表名。也可以指定schema_name.table_name

示例

  1. --创建doc
  2. openGauss=# create table doc(id serial primary key, content varchar(255));
  3. NOTICE: CREATE TABLE will create implicit sequence "doc_id_seq" for serial column "doc.id"
  4. NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "doc_pkey" for table "doc"
  5. CREATE TABLE
  6. --插入10000条数据
  7. openGauss=# insert into doc(content) select 'abcd1234' from generate_series(1,10000) as content;
  8. INSERT 0 100000
  9. --删除9000条数据
  10. openGauss=# delete from doc where id <= 9000;
  11. DELETE 9000
  12. --optimize
  13. openGauss=# optimize table doc;
  14. VACUUM
  15. --optimize表(查看处理详情)
  16. openGauss=# optimize verbose table doc;
  17. INFO: vacuuming "public.doc"(primary pid=24692)
  18. INFO: "doc": found 9000 removable, 1000 nonremovable row versions in 55 pages(primary pid=24692)
  19. DETAIL: 0 dead row versions cannot be removed yet.
  20. CPU 0.00s/0.04u sec elapsed 0.04 sec.
  21. INFO: analyzing "public.doc"(primary pid=24692)
  22. INFO: ANALYZE INFO : "doc": scanned 6 of 6 pages, containing 1000 live rows and 0 dead rows; 1000 rows in sample, 1000 estimated total rows(primary pid=24692)
  23. VACUUM