Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Applies to:  Databricks SQL
 Databricks SQL  Databricks Runtime
 Databricks Runtime
Deletes the table and removes the directory associated with the table from the file system
if the table is not an EXTERNAL table. An exception is thrown if the table does not exist.
To drop a table you must have the MANAGE privilege on the table, be its owner, or the owner of the schema, catalog, or metastore the table resides in.
In the case of an external table, only the associated metadata information is removed from the metastore schema.
Any foreign key constraints referencing the table are also dropped.
If the table is cached, the command uncaches the table and all of its dependents.
Note
Tables are deleted within 7 to 30 days. Unity Catalog supports the UNDROP TABLE command to recover dropped managed tables for 7 days. After 7 days, the underlying data is marked for deletion from your cloud tenant during regular table maintenance operations.
Syntax
DROP TABLE [ IF EXISTS ] table_name [ FORCE ]
Parameter
- IF EXISTS - If specified, no TABLE_OR_VIEW_NOT_FOUND error is thrown when the table does not exist. 
- 
The name of the table to be dropped. The name must not include a temporal specification or options specification. If the table cannot be found Azure Databricks raises a TABLE_OR_VIEW_NOT_FOUND error. If the relation found is not a table Azure Databricks raises a WRONG_COMMAND_FOR_OBJECT_TYPE error. 
- FORCE - If specified, the table can be dropped even if it has dependent shallow clones. This is only applicable for Unity Catalog managed tables. See Drop the base table for a shallow clone. 
Examples
-- Assumes a table named `employeetable` exists.
> DROP TABLE employeetable;
-- Assumes a table named `employeetable` exists in the `userdb` schema
> DROP TABLE userdb.employeetable;
-- Assumes a table named `employeetable` does not exist.
-- Throws TABLE_OR_VIEW_NOT_FOUND
> DROP TABLE employeetable;
  Error: TABLE_OR_VIEW_NOT_FOUND
-- Assumes a table named `employeetable` does not exist,Try with IF EXISTS
-- this time it will not throw exception
> DROP TABLE IF EXISTS employeetable;
-- Assumes a table named `employeetable` exists and has a shallow clone.
-- Throws CANNOT_DROP_BASE_TABLE_REFERENCED_BY_SHALLOW_CLONE
> DROP TABLE employeetable;
  Error: CANNOT_DROP_BASE_TABLE_REFERENCED_BY_SHALLOW_CLONE
-- Assumes a table named `employeetable` exists and has a shallow clone.
-- Drops base table, but shallow clones referencing this base table will no longer work
> DROP TABLE employeetable FORCE;