3

该文档清楚地说明了如何清除 Oracle AQ:

dbms_aqadm.purge_queue_table()

但是,存储会发生什么变化,尤其是队列表、索引和 LOB 段的高水位标记?是否也需要缩小表?

在生产中,队列几乎总是空的(应该如此),但在我们的测试系统中,由于各种原因,它们会填满数百万行,因此有时需要清空它们。

是否有必要查看基础表和索引,还是自动处理?

非常感谢!

4

1 回答 1

2

DBMS_AQADM.PURGE_QUEUE_TABLE它相当于截断表。当您尝试截断队列表时,还要查看此错误消息

ORA-24005: Inappropriate utilities used to perform DDL on AQ table %s.%s
 *Cause:  An attempt was made to use the SQL command DROP TABLE or TRUNCATE
          TABLE or ALTER TABLE on queue metadata or tables.
 *Action: Use the DBMS_AQADM.DROP_QUEUE_TABLE to DROP TABLE,
          DBMS_AQADM.PURGE_QUEUE_TABLE to TRUNCATE TABLE.
          ALTER TABLE redefinition based on only ALTER_TABLE_PROPERTIES and
          ALTER_TABLE_PARTITIONING clauses are allowed.

Tom Kyte 已经写过关于经常截断表的信息https://asktom.oracle.com/pls/apex/f?p=100:11:0::::P11_QUESTION_ID:47911859692542

于 2016-07-27T13:03:11.587 回答