python 连接SQL server 请用pymssql连接,千万别用pyodbc

pymssql官方介绍文档
python 使用 pymssql连接 SQL server 代码示例:
安装pymssql包:

pip install pymssql

代码:

import pymssql

def conn_sqlserver_demo():
    # 连接字符串示例(根据您的配置进行修改)
    conn = None
    try:
        conn = pymssql.connect(
            server=f"host地址",
            port='1433',# port可以不写,不写默认1433
            user="数据库登录用户名",
            password="数据库登录密码",
            database="数据库名",
            as_dict=False, # True结果返回字典形式,False(默认)结果返回元组形式
            charset='cp936' ## 数据库编码格式,如果返回结果中文乱码,请修改这里
        )
        cursor = conn.cursor()
        cursor.execute('select * from dbo.Doctor')
        for row in cursor:
            print(row)
    except Exception as e:
    	traceback.print_exc()  # 回调函数,输出异常信息
    	conn.rollback()
        print("连接数据库时发生错误:", str(e))
    finally:
        conn.close()

解释一下为什么python连接sqlserver推荐使用pymssql,而不推荐pyodbc;

SQL server 是微软家的东西,ODBC也是微软家的东西,对除了windows以外的其他操作系统十分不友好,还要额外下载odbc驱动,尤其是需要在liunx系列服务器上使用时,配置的时候,足够叫你哭爹喊娘,本人亲自踩坑;
而pymssql 不需要安装其他任何驱动,而且开源,跨平台性更好;

补充一下:pyodbc 连接 sqlserver

def conn_sqlserver_demo():
    conn = None
    connection_string = f"Driver={{SQL Server}};Server=127.0.0.1,1433;Database=数据库名;Uid=数据库用户名;Pwd=数据库用户密码;"
    try:
        conn = pyodbc.connect(connection_string)
        cursor = conn.cursor()
        cursor.execute('select * from dbo.Doctor')
        for row in cursor:
            print(row)
    except Exception as e:
        traceback.print_exc()
        conn.rollback()
        print("连接数据库时发生错误:", str(e))
    finally:
        conn.close()

服务器配置sqlserver odbc驱动,亲测一般般,并没有解决问题
出现公钥不可用报错,解决办法:The following signatures couldn’t be verified because the public key is not available: NO_PUBKEY EB3E94ADBE1229CF
微软官方配置python连接SQL server链接
在这里插入图片描述

### PyODBC PyMSSQL 的区别及用途 #### 功能特性差异 PyMSSQL 不需要额外安装驱动程序即可连接 Microsoft SQL Server 数据库,这使得其在某些旧版操作系统上的兼容性更好[^2]。相比之下,PyODBC 需要依赖于 ODBC 驱动来建立与数据库之间的通信桥梁。 对于字符编码的支持也存在不同之处,在处理包含中文字符的数据时,使用 PyMSSQL 可能会遇到 `varchar` 类型字段中的数据出现乱码的情况;此时建议改用支持 Unicode 编码的 `nvarchar` 类型以避免此类问题的发生。而在相同场景下,PyODBC 则不会遭遇同样的困扰。 #### 安装方式对比 为了能够正常使用这两个模块之一来进行开发工作,开发者可以采用如下命令通过 pip 工具完成相应软件包的下载与部署: - 对于 PyMSSQL 来说,仅需执行简单的指令即可实现自动化安装过程: ```bash pip install pymssql ``` - 而针对 PyODBC,则除了上述类似的步骤外,还需要确保目标机器已经预先配置好了合适的 ODBC Driver 版本[^3]。 #### 示例代码展示 以下是利用这两种方法分别向名为 "Author" 表内插入一条记录的具体实现方式: ##### 使用 PyMSSQL 插入数据 ```python import pymssql conn = pymssql.connect(server='localhost', user='sa', password='YourPassword!', database='testdb') cursor = conn.cursor() cursor.execute("INSERT INTO Author (name, address) VALUES (%s,%s)", ('张三', '北京市')) conn.commit() conn.close() ``` 请注意这里将地址列定义为 nvarchar 类型以防可能存在的汉字显示异常情况发生。 ##### 使用 PyODBC 插入数据 ```python import pyodbc conn_str = ( r'DRIVER={SQL Server};' r'SERVER=localhost;' r'DATABASE=testdb;' r'UID=sa;' r'PWD=YourPassword!' ) with pyodbc.connect(conn_str) as connection: with connection.cursor() as cursor: sql_query = """\ INSERT INTO Author (name, address) VALUES (?, ?); """ params = ['李四', '上海市'] cursor.execute(sql_query, params) connection.commit() ``` 这段代码展示了如何借助上下文管理器简化资源释放流程,并且由于 PyODBC 自身良好的国际化支持能力,因此可以直接传递字符串参数而无需担心特殊字符集带来的麻烦。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大脑经常闹风暴@小猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值