turbodbc连接数据库方法模板

如果已经安装好 turbodbc,我们可以用它在 Jupyter Notebook 中连接数据库(比如 SQL Server、MySQL、PostgreSQL 等)。以下是一个通用的连接方法模板,可以根据自己的数据库类型和配置进行调整。


✅ 示例:使用 turbodbc 连接 SQL Server 的方法

python 复制代码
import turbodbc
import pandas as pd

def get_db_connection(driver='{ODBC Driver 17 for SQL Server}',
                      server='localhost',
                      database='your_database',
                      uid='your_username',
                      pwd='your_password'):
    """
    使用 turbodbc 创建数据库连接。
    
    参数:
    - driver: ODBC 驱动名称(可在 ODBC 数据源管理器中查看)
    - server: 数据库地址(如 localhost 或 IP)
    - database: 数据库名称
    - uid: 用户名
    - pwd: 密码
    
    返回:
    - turbodbc 连接对象
    """
    connection_string = (
        f"Driver={driver};"
        f"Server={server};"
        f"Database={database};"
        f"UID={uid};"
        f"PWD={pwd};"
        f"Trusted_Connection=no;"
    )
    return turbodbc.connect(connection_string=connection_string)


def query_to_df(sql, conn):
    """
    执行 SQL 并返回 DataFrame。
    
    参数:
    - sql: 查询语句
    - conn: turbodbc 连接对象
    
    返回:
    - pandas DataFrame
    """
    cursor = conn.cursor()
    cursor.execute(sql)
    return cursor.fetchallarrow().to_pandas()

🔍 示例调用:

ini 复制代码
conn = get_db_connection(
    driver='{ODBC Driver 17 for SQL Server}',
    server='127.0.0.1',
    database='MyDB',
    uid='sa',
    pwd='your_password'
)

df = query_to_df("SELECT TOP 10 * FROM my_table", conn)
df.head()

📌 注意事项:

  • 要确保你安装了 正确版本的 ODBC 驱动,如:

    • SQL Server: {ODBC Driver 17 for SQL Server}{ODBC Driver 18 for SQL Server}
    • MySQL: {MySQL ODBC 8.0 Unicode Driver}
    • PostgreSQL: {PostgreSQL Unicode(x64)}
  • 如果你使用的是 Windows 身份验证(即无需输入用户名密码),可将 Trusted_Connection=yes 并去掉 UIDPWD


相关推荐
爱勇宝9 分钟前
别焦虑,也别躺平:给年轻程序员的一封信
前端·后端·架构
Full Stack Developme24 分钟前
Spring 发展历史
java·后端·spring
ClouGence33 分钟前
TiCDC 够用吗?聊聊 TiDB 同步的几个关键问题
数据库·分布式·后端
音符犹如代码1 小时前
Docker 一键部署带有 TimescaleDB 插件的 PostgreSQL
java·运维·数据库·后端·docker·postgresql·容器
LucianaiB1 小时前
从模型护栏到工程门禁:基于 XGuard 二创一个 Agent/CI 动态策略安全护栏
后端
铁皮饭盒1 小时前
同样是算力巨头,为什么华为死磕英伟达,AMD 却 "躺平看戏"?
前端·后端
文心快码BaiduComate1 小时前
用Comate 7天完成”鹅鸭杀”游戏网站开发
前端·后端·程序员
倚栏听风雨2 小时前
Spring AI Alibaba 接入 OpenAI 兼容协议第三方大模型实战
后端
夕除2 小时前
spring boot 6
java·spring boot·后端
zhangxingchao2 小时前
AI应用开发二:Embedding与向量数据库
前端·人工智能·后端