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


相关推荐
shark_chili31 分钟前
网卡数据包处理全攻略:DMA、中断、NAPI机制深度解析
后端
RoyLin32 分钟前
命名实体识别
前端·后端·typescript
RoyLin1 小时前
微任务与宏任务
前端·后端·node.js
IT_陈寒1 小时前
Redis 性能提升秘籍:这5个被低估的命令让你的QPS飙升200%
前端·人工智能·后端
余衫马8 小时前
Windows 10 环境下 Redis 编译与运行指南
redis·后端
青柠编程10 小时前
基于Spring Boot的竞赛管理系统架构设计
java·spring boot·后端
s91236010111 小时前
【rust】 pub(crate) 的用法
开发语言·后端·rust
夕颜11113 小时前
关于排查问题的总结
后端
码事漫谈13 小时前
揭秘RAG的核心引擎:Document、Embedding与Retriever详解
后端
码事漫谈13 小时前
BM25 检索是什么
后端