跳到主要内容

DELETE_TABLE_STATS

DELETE_TABLE_STATS 过程用于删除表级的统计信息。

语法

DBMS_STATS.DELETE_TABLE_STATS (
ownname VARCHAR2,
tabname VARCHAR2,
partname VARCHAR2 DEFAULT NULL,
cascade_parts BOOLEAN DEFAULT TRUE,
cascade_columns BOOLEAN DEFAULT TRUE,
no_invalidate BOOLEAN DEFAULT FALSE,
force BOOLEAN DEFAULT FALSE);

参数解释

参数解释
ownname用户名。如果用户名设置为 NULL,会默认使用当前登录的用户名。
tabname此列所属的表名。
partname从中获取统计信息的表所在(子)分区的名称。如果表已分区而 partnameNULL,则从全局表级别检索统计信息。
cascade_parts是否同时删除分区级、子分区级的统计信息,默认为 TRUE
cascade_columns是否同时删除列级的统计信息,默认为 TRUE
no_invalidate收集统计信息时是否刷 Plan Cache。设置为 TRUE 表示收集统计信息时不刷 Plan Cache。
force是否强制收集,并忽略锁的状态。默认为 FALSE。如果设置为 TRUE,即使统计信息被锁定,也会收集统计信息。

异常情况

错误码描述
HY000
  • 该表不存在或权限不足。
  • 用户统计表已损坏,可能需要升级。
  • 该对象的统计信息被锁定。

使用说明

要调用此过程,您必须是表的所有者。

示例

删除用户 testUser01 的表 tbl1 的所有统计信息。

CALL DBMS_STATS.DELETE_TABLE_STATS('testUser01', 'tbl1');
Query OK, 0 rows affected