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


相关推荐
高山上有一只小老虎14 小时前
SpringBoot项目集成thymeleaf实现web
前端·spring boot·后端
瑾修15 小时前
golang查找cpu过高的函数
开发语言·后端·golang
yangminlei21 小时前
Spring Boot3集成LiteFlow!轻松实现业务流程编排
java·spring boot·后端
计算机毕设VX:Fegn089521 小时前
计算机毕业设计|基于springboot + vue医院设备管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
J_liaty21 小时前
Spring Boot整合Nacos:从入门到精通
java·spring boot·后端·nacos
面汤放盐1 天前
后端系统设计文档模板
后端
2***d8851 天前
SpringBoot 集成 Activiti 7 工作流引擎
java·spring boot·后端
五阿哥永琪1 天前
Spring中的定时任务怎么用?
java·后端·spring
追逐时光者1 天前
C#/.NET/.NET Core技术前沿周刊 | 第 65 期(2026年1.1-1.11)
后端·.net
计算机毕设VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue小型房屋租赁系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计