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
Clones a source Delta, managed Apache Iceberg, or Apache Parquet table to a target location at a specific version. Cloning can be either deep or shallow: deep clones copy the data, while shallow clones reference the source data without copying it.
- Delta, Parquet, and Foreign Iceberg tables support both deep and shallow cloning.
- Managed Iceberg tables support only deep cloning, and you can't change the table format during cloning.
For more information, see Incrementally clone Parquet and Apache Iceberg tables to Delta Lake.
In Databricks SQL and Databricks Runtime 13.3 LTS and above, you can use shallow clone with Unity Catalog managed tables. In Databricks Runtime 12.2 LTS and below, there is no support for shallow clones in Unity Catalog. See Shallow clone for Unity Catalog tables.
Important
There are important differences between shallow and deep clones that can determine how best to use them. See Clone a table on Azure Databricks.
Syntax
CREATE TABLE [IF NOT EXISTS] table_name
   [SHALLOW | DEEP] CLONE source_table_name [TBLPROPERTIES clause] [LOCATION path]
[CREATE OR] REPLACE TABLE table_name
   [SHALLOW | DEEP] CLONE source_table_name [TBLPROPERTIES clause] [LOCATION path]
Parameters
- IF NOT EXISTS - If specified, the statement is ignored if - table_namealready exists.
- [CREATE OR] REPLACE - If - CREATE ORis specified the table is replaced if it exists and newly created if it does not. Without- CREATE ORthe- table_namemust exist.
- 
The name of the table to be created. The name must not include a temporal specification or options specification. If the name is not qualified the table is created in the current schema. table_namemust not exist already unlessREPLACEorIF NOT EXISTShas been specified.
- SHALLOW CLONE or DEEP CLONE - If you specify - SHALLOW CLONEAzure Databricks will make a copy of the source table's definition, but refer to the source table's files. When you specify- DEEP CLONE(default) Azure Databricks will make a complete, independent copy of the source table.- Managed Iceberg tables only support deep cloning, not shallow cloning. 
- 
The name of the table to be cloned. The name may include a temporal specification or options specifiation. 
- 
Optionally sets one or more user-defined properties. 
- LOCATION path - Optionally creates an external table, with the provided location as the path where the data is stored. If - table_nameitself is a path instead of a table identifier, the operation will fail.- pathmust be a STRING literal.
Examples
You can use CREATE TABLE CLONE for complex operations like data migration, data archiving, machine learning flow reproduction, short-term experiments, and data sharing. See Clone a table on Azure Databricks.