The LOCK_SCHEMA_STATS procedure locks statistics for all tables in a schema.
Syntax
DBMS_STATS.LOCK_SCHEMA_STATS(
ownname VARCHAR2,
stattype VARCHAR2 DEFAULT 'ALL');
Parameters
| Parameter | Description |
|---|---|
| ownname | The name of the schema. |
| stattype | The type of the statistics to be locked. Three types are supported:
'ALL' type. |
Considerations
To call this procedure, you must be the owner of the table. If the object is in the
systenant, you must be the owner of the table or have theSYSDBAprivilege.When statistics on a table are locked, all statistics dependent on the table are locked, including table-level statistics, column-level statistics, histogram statistics, and statistics on all dependent indexes.
If the statistics on an object are locked, an error occurs when you execute a
SET_*,DELETE_*,IMPORT_*, orGATHER_*procedure to modify the statistics on a single table, index, or column.When you call the
EXPORT_*_STATSprocedure, the lock or unlock status is not exported with the table-level statistics.The
UNLOCK_SCHEMA_STATSorUNLOCK_TABLE_STATSprocedure cannot unlock the statistics on corresponding partitions. When you call theLOCK_TABLE_STATSprocedure, it will set a table-level lock position. In this case, you cannot collect statistics on dependent objects such as partitions and indexes. In addition, if table-level statistics are locked, the dependent objects are also locked. In this case, you do not need to explicitly call theLOCK_PARTITION_STATSprocedure to lock partition statistics.
Examples
Lock the statistics on all tables in the hr schema.
obclient> CALL DBMS_STATS.LOCK_SCHEMA_STATS(ownname=>'hr', stattype=>'ALL');
Query OK, 0 rows affected