Azure Databricks 提供专用于 Azure Databricks 的 SQLAlchemy方言(这是 SQLAlchemy 用于与各种类型的数据库 API 实现和数据库通信的系统)。 SQLAlchemy 是 Python SQL 工具包和对象关系映射器 (ORM)。 SQLAlchemy 提供了一整套众所周知的企业级持久性模式,旨在实现高效且高性能的数据库访问,并采用简单的 Pythonic 域语言。 请参阅特征和理念。
需要安装 Azure Databricks 的 SQLAlchemy 方言才能将 SQLAlchemy 功能与 Azure Databricks 配合使用。 本文介绍适用于 Azure Databricks 版本 1.0 和 2.0 的 SQLAlchemy 方言,该方言将基于用于 Python 4.0.0 或更高版本的 Databricks SQL 连接器。
要求
- 运行 Python >=3.8 和<=3.11 的开发计算机。
- Databricks 建议使用 Python 虚拟环境,例如 python 随附的 venv 提供的环境。 虚拟环境有助于确保同时使用正确版本的 Python 和适用于 Python 的 Databricks SQL 连接器。 设置和使用虚拟环境不在本文的讨论范围之内。 有关详细信息,请参阅创建虚拟环境。
- 现有群集或 SQL 仓库。
入门
请使用
pip install databricks-sqlalchemy~=1.0
(针对 SQLAlchemy v1)或pip install databricks-sqlalchemy
(针对 SQLAlchemy v2)安装 databricks-sqlalchemy。 有关版本信息,请参阅 databricks-sqlalchemy 发布历史记录。收集想要使用的群集或 SQL 仓库的以下信息:
群集
- 群集的服务器主机名。 从您群集的“高级选项”> JDBC/ODBC选项卡中的“服务器主机名”值可以获取此信息。
- 群集的 HTTP 路径。 从群集的>选项卡的“HTTP 路径”值中可以获取此路径。
SQL 仓库
- SQL 仓库的服务器主机名。 您可以从 SQL 仓库的“连接详细信息”选项卡中的“服务器主机名”值中获取此信息。
- SQL 仓库的 HTTP 路径。 从 SQL 仓库的“连接详细信息”选项卡的“HTTP 路径”值中可以获取此路径。
身份验证
Azure Databricks 的 SQLAlchemy 方言支持 Azure Databricks 个人访问令牌身份验证。
要创建 Azure Databricks 个人访问令牌,请遵循适用于工作区用户的 Azure Databricks 个人访问令牌中的步骤。
要对 SQLAlchemy 方言进行身份验证,请使用以下代码片段。 此代码片段假定你已设置以下环境变量:
DATABRICKS_TOKEN
,设置为 Azure Databricks 个人访问令牌。DATABRICKS_SERVER_HOSTNAME
,设置为群集或 SQL 仓库的“服务器主机名”值。DATABRICKS_HTTP_PATH
,设置为群集或 SQL 仓库的“HTTP 路径”值。DATABRICKS_CATALOG
,设置为 Unity Catalog 中的目标目录。DATABRICKS_SCHEMA
,设置为 Unity Catalog 中的目标架构(也称为数据库)。
若要设置环境变量,请参阅操作系统的文档。
import os
from sqlalchemy import create_engine
access_token = os.getenv("DATABRICKS_TOKEN")
server_hostname = os.getenv("DATABRICKS_SERVER_HOSTNAME")
http_path = os.getenv("DATABRICKS_HTTP_PATH")
catalog = os.getenv("DATABRICKS_CATALOG")
schema = os.getenv("DATABRICKS_SCHEMA")
engine = create_engine(
url = f"databricks://token:{access_token}@{server_hostname}?" +
f"http_path={http_path}&catalog={catalog}&schema={schema}"
)
# ...
可使用上述 engine
变量通过 Azure Databricks 计算资源连接到指定的目录和架构。
SQLAlchemy v1
有关连接示例,请参阅此 example.py
SQLAlchemy v2
有关连接示例,请参阅以下部分和 GitHub 中的 sqlalchemy_example.py 文件。
DBAPI 参考
- databricks-sqlalchemy v1 GitHub 存储库
- SQLAlchemy v1 README.md
- databricks-sqlalchemy v2 GitHub 存储库
- SQLAlchemy v2 README.md