Python怎样操作Microsoft SQL Server?pyodbc配置

星夢妙者
发布: 2025-08-17 22:56:01
原创
963人浏览过

python操作sql server最常用且推荐的方法是使用pyodbc,首先需安装sql server客户端工具并配置odbc数据源,然后通过pip install pyodbc安装库,接着根据身份验证方式编写正确的连接字符串,如使用sql server身份验证或windows身份验证,并确保服务器名、数据库名、用户名、密码、驱动版本、防火墙设置及sql server配置(如启用tcp/ip协议)均正确无误,连接成功后可通过参数化查询(使用?占位符传递参数)有效防止sql注入,此外虽有pymssql等替代库,但pyodbc因支持广泛、性能优越而更受推荐,最终在代码中需妥善处理异常并关闭连接以确保资源释放。

Python怎样操作Microsoft SQL Server?pyodbc配置

直接操作SQL Server,Python有几种方法,最常用也比较推荐的是

pyodbc
登录后复制
。配置起来稍微有点麻烦,但用起来是真的香。

解决方案

要用

pyodbc
登录后复制
连接SQL Server,首先你得确保你的环境里已经安装了SQL Server客户端工具,并且配置好了ODBC数据源。这步是基础,没搞定后面啥都白搭。

然后,安装

pyodbc
登录后复制

立即学习Python免费学习笔记(深入)”;

pip install pyodbc
登录后复制

连接字符串是关键,不同的验证方式写法不一样,这里给几个例子:

  • 使用SQL Server身份验证:

    import pyodbc
    
    connection_string = (
        r'DRIVER={SQL Server};'
        r'SERVER=your_server_name;'
        r'DATABASE=your_database_name;'
        r'UID=your_username;'
        r'PWD=your_password;'
    )
    
    try:
        cnxn = pyodbc.connect(connection_string)
        cursor = cnxn.cursor()
    
        # 执行SQL查询
        cursor.execute("SELECT * FROM your_table")
        rows = cursor.fetchall()
    
        for row in rows:
            print(row)
    
    except pyodbc.Error as ex:
        sqlstate = ex.args[0]
        print(f"数据库连接失败: {sqlstate}")
    
    finally:
        if cnxn:
            cnxn.close()
    登录后复制
  • 使用Windows身份验证:

    import pyodbc
    
    connection_string = (
        r'DRIVER={SQL Server};'
        r'SERVER=your_server_name;'
        r'DATABASE=your_database_name;'
        r'Trusted_Connection=yes;'
    )
    
    try:
        cnxn = pyodbc.connect(connection_string)
        cursor = cnxn.cursor()
    
        # 执行SQL查询
        cursor.execute("SELECT * FROM your_table")
        rows = cursor.fetchall()
    
        for row in rows:
            print(row)
    
    except pyodbc.Error as ex:
        sqlstate = ex.args[0]
        print(f"数据库连接失败: {sqlstate}")
    
    finally:
        if cnxn:
            cnxn.close()
    登录后复制

记得替换

your_server_name
登录后复制
your_database_name
登录后复制
your_username
登录后复制
your_password
登录后复制
为你的实际值。Windows身份验证的话,确保你的Windows账户有访问SQL Server的权限。

为什么我连接SQL Server总是报错?常见错误排查

连接错误五花八门,但通常离不开这几个原因:

壁纸样机神器
壁纸样机神器

免费壁纸样机生成

壁纸样机神器 0
查看详情 壁纸样机神器
  1. 驱动没装好: 确保SQL Server的ODBC驱动正确安装,版本要对。有时候32位Python配64位驱动,或者反过来,都会出问题。

  2. 连接字符串写错了: 服务器名、数据库名、用户名、密码,任何一个写错都连不上。注意大小写,特殊字符。

  3. 防火墙挡住了: SQL Server默认端口是1433,检查防火墙有没有阻止Python访问这个端口。

  4. SQL Server配置问题: SQL Server可能禁用了TCP/IP协议,或者不允许远程连接。用SQL Server Configuration Manager检查一下。

  5. 权限不足: 你的SQL Server账户可能没有访问特定数据库或表的权限。

如何用
pyodbc
登录后复制
执行参数化查询,防止SQL注入?

SQL注入是个大坑,千万要避免。用参数化查询可以有效防止。

import pyodbc

connection_string = (
    r'DRIVER={SQL Server};'
    r'SERVER=your_server_name;'
    r'DATABASE=your_database_name;'
    r'UID=your_username;'
    r'PWD=your_password;'
)

try:
    cnxn = pyodbc.connect(connection_string)
    cursor = cnxn.cursor()

    # 参数化查询示例
    sql = "SELECT * FROM your_table WHERE column1 = ? AND column2 = ?"
    params = ('value1', 'value2')  # 替换为实际的值

    cursor.execute(sql, params)
    rows = cursor.fetchall()

    for row in rows:
        print(row)

except pyodbc.Error as ex:
    sqlstate = ex.args[0]
    print(f"数据库连接失败: {sqlstate}")

finally:
    if cnxn:
        cnxn.close()
登录后复制

看到没,SQL语句里用

?
登录后复制
占位,实际的值通过
params
登录后复制
传进去。
pyodbc
登录后复制
会自动处理转义,不用担心恶意代码。

除了
pyodbc
登录后复制
,还有其他Python库可以操作SQL Server吗?

当然有,比如

pymssql
登录后复制
。但
pyodbc
登录后复制
更通用,支持的数据库类型更多,而且性能通常更好。
pymssql
登录后复制
有时候在处理一些特殊数据类型上可能更方便,但总体来说,
pyodbc
登录后复制
是更推荐的选择。

以上就是Python怎样操作Microsoft SQL Server?pyodbc配置的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号