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.
Important
This feature is in Public Preview.
Azure Databricks provides access to Unity Catalog tables using the Unity REST API and Apache Iceberg REST catalog.
A metastore admin must enable external data access for each metastore you need to access externally. The user or service principal that configures the connection must have the EXTERNAL USE SCHEMA privilege for each schema where they need to perform supported operations: reading from managed tables or creating, reading, and writing to external tables.
The Unity REST API supports direct reads for Delta tables. The Iceberg REST catalog supports reads for Delta tables and reads and writes for Iceberg tables. See Access Databricks data using external systems.
Enable external data access on the metastore
To allow external engines to access data in a metastore, a metastore admin must enable external data access for the metastore. This option is disabled by default to prevent unauthorized external access.
To enable external data access, do the following:
- In an Azure Databricks workspace attached to the metastore, click - Catalog. 
- Click the - gear icon at the top of the Catalog pane and select Metastore. 
- On the Details tab, enable External data access. 
Note
These options are only displayed for sufficiently privileged users. If you do not see these options, you do not have permissions to enable external data access for a metastore.
Grant a principal Unity Catalog privileges
External clients connecting to Azure Databricks need authorization from a sufficiently privileged principal.
Azure Databricks supports OAuth and personal access tokens (PAT) for authentication. See Authorizing access to Azure Databricks resources.
The principal who requests the temporary credential must have:
- The - EXTERNAL USE SCHEMAprivilege on the containing schema or its parent catalog.- This privilege must always be granted explicitly. Only the parent catalog owner can grant it. To avoid accidental exfiltration, - ALL PRIVILEGESdoes not include the- EXTERNAL USE SCHEMAprivilege, and schema owners do not have this privilege by default.
- SELECTpermission on the table,- USE CATALOGon its parent catalog, and- USE SCHEMAon its parent schema.
- If creating external tables, the principal must also have the - CREATE TABLEprivilege on the schema and both the- CREATE EXTERNAL TABLEand- EXTERNAL USE LOCATIONprivileges on the target external location.- EXTERNAL USE LOCATIONmust always be granted explicitly. Only users with the- MANAGEprivilege on the external location can grant it. To avoid accidental exfiltration,- ALL PRIVILEGESdoes not include the- EXTERNAL USE LOCATIONprivilege, and location owners do not have this privilege by default.
The following example syntax demonstrates granting EXTERNAL USE SCHEMA to a user:
GRANT EXTERNAL USE SCHEMA ON SCHEMA catalog_name.schema_name TO `user@company.com`
The following example syntax demonstrates granting EXTERNAL USE LOCATION to a user:
GRANT EXTERNAL USE LOCATION ON EXTERNAL LOCATION external_location_name TO `user@company.com`
Assuming the user has the permissions to read all desired tables in the schema, no additional permissions are needed. If you need to grant additional permissions to read tables, see Unity Catalog privileges and securable objects.