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.
Note
This article applies to the Databricks JDBC driver, below version 3. For the most recent Databricks JDBC driver, version 3 and above, see Databricks JDBC Driver.
This article describes how to upload, download, and delete files in Unity Catalog volumes using the Databricks JDBC Driver.
Requirements
- Databricks JDBC Driver versions 2.6.38 or above.
- By default, native query mode is enabled. Otherwise, add UseNativeQueryproperty to the JDBC connection string, setting its value to1or2.
For a complete Java code example showing how to run this article's code snippets in the context of setting up Azure Databricks authentication and running SQL statements withe the Databricks JDBC Driver, see Authentication settings for the Databricks JDBC Driver (Simba).
Upload a file
To upload a file to a volume, you must add the StagingAllowedLocalPaths property to the JDBC connection string, setting this property's value to the path of the file to upload. To upload multiple files from separate locations, set this property to a comma-separated list of paths, for example /tmp/,/usr/tmp/.
Important
If the JDBC is setup in a multi-tenant environment (such as BI tools or developer services), and the users control the full JDBC URL, the service should set the connection property StagingAllowedLocalPaths to a sandbox location or a non-existent path. This prevents users from writing arbitraty files and interferring with the service's internal deployment.
To override the contents of any existing file in the specified upload location, add OVERWRITE.
The following Java code snippet shows how to upload a file to a volume.
// ...
p.put("StagingAllowedLocalPaths", "/tmp/");
Connection conn = DriverManager.getConnection(url, p);
Statement stmt = conn.createStatement();
stmt.executeQuery("PUT '" +
                  "/tmp/my-data.csv" +
                  "' INTO '" +
                  "/Volumes/main/default/my-volume/my-data.csv" +
                  "' OVERWRITE")
// ...
Download a file
The following Java code snippet shows how to download a file from a volume.
// ...
Connection conn = DriverManager.getConnection(url, p);
Statement stmt = conn.createStatement();
stmt.executeQuery("GET '" +
                  "/Volumes/main/default/my-volume/my-data.csv" +
                  "' TO '" +
                  "/tmp/my-downloaded-data.csv" +
                  "'")
// ...
Delete a file
The following Java code snippet shows how to delete a file from a volume.
// ...
Connection conn = DriverManager.getConnection(url, p);
Statement stmt = conn.createStatement();
stmt.executeQuery("REMOVE '" +
                  "/Volumes/main/default/my-volume/my-data.csv" +
                  "'")
// ...