Use the DROP
MATERIALIZED
VIEW
statement to remove an existing materialized view from the database.
When you drop a materialized view, Oracle Database does not place it in the recycle bin. Therefore, you cannot subsequently either purge or undrop the materialized view.
Note:
The keywordSNAPSHOT
is supported in place of MATERIALIZED
VIEW
for backward compatibility.See Also:
CREATE MATERIALIZED VIEW for more information on the various types of materialized views
ALTER MATERIALIZED VIEW for information on modifying a materialized view
Oracle Database Advanced Replication for information on materialized views in a replication environment
Oracle Database Data Warehousing Guide for information on materialized views in a data warehousing environment
The materialized view must be in your own schema or you must have the DROP
ANY
MATERIALIZED
VIEW
system privilege. You must also have the privileges to drop the internal table, views, and index that the database uses to maintain the materialized view data.
See Also:
DROP TABLE, DROP VIEW, and DROP INDEX for information on privileges required to drop objects that the database uses to maintain the materialized viewSpecify the schema containing the materialized view. If you omit schema
, then Oracle Database assumes the materialized view is in your own schema.
Specify the name of the existing materialized view to be dropped.
If you drop a simple materialized view that is the least recently refreshed materialized view of a master table, then the database automatically purges from the master table materialized view log only the rows needed to refresh the dropped materialized view.
If you drop a materialized view that was created on a prebuilt table, then the database drops the materialized view, and the prebuilt table reverts to its identity as a table.
When you drop a master table, the database does not automatically drop materialized views based on the table. However, the database returns an error when it tries to refresh a materialized view based on a master table that has been dropped.
If you drop a materialized view, then any compiled requests that were rewritten to use the materialized view will be invalidated and recompiled automatically. If the materialized view was prebuilt on a table, then the table is not dropped, but it can no longer be maintained by the materialized view refresh mechanism.
This clause lets you retain the materialized view container table and its contents after the materialized view object is dropped. The resulting table has the same name as the dropped materialized view.
Oracle Database removes all metadata associated with the materialized view. However, indexes created on the container table automatically during creation of the materialized view are preserved, with one exception: the index created during the creation of a rowid materialized view is dropped. Also, if the materialized view has any nested table columns, then the storage tables for those columns are preserved, along with their metadata.
Restriction on the PRESERVE TABLE Clause This clause is not valid for materialized views that have been imported from releases earlier than Oracle9i, when these objects were called "snapshots".
Dropping a Materialized View: Examples The following statement drops the materialized view emp_data
in the sample schema hr
:
DROP MATERIALIZED VIEW emp_data;
The following statement drops the sales_by_month_by_state
materialized view and the underlying table of the materialized view, unless the underlying table was registered in the CREATE
MATERIALIZED
VIEW
statement with the ON
PREBUILT
TABLE
clause:
DROP MATERIALIZED VIEW sales_by_month_by_state;