当前位置: 首页 > news >正文

【已解决】pyodbc 5.2 [ODBC 驱动程序管理器] 未发现数据源名称并且未指定默认驱动程序

问题

当升级 pyodbc 5.2 版本后,连接 sqlserver 数据库,报错如下:

连接失败: ('IM002', '[IM002] [Microsoft][ODBC 驱动程序管理器] 未发现数据源名称并且未指定默认驱动程序 (0) (SQLDriverConnect); [IM002] [Microsoft][ODBC 驱动程序管理器] 无效的连接字符串属性 (0)')

解决

  1. 确定驱动已安装

    若驱动不存在,需先下载 ODBC Driver for SQL Server

    # 1. 确定驱动安装正常
    print(pyodbc.drivers())  
    # ['ODBC Driver 18 for SQL Server']
    
  2. 重要】若 pyodbc 库从 4.0 版本升级,且连接数据库语句如下:

    import pyodbc
    
    # 此代码为错误使用参数
    # pyodbc4.0版本中 connect 方法中并没有 encoding 参数,此时设置无效
    # 而 pyodbc5+ 版本中,encoding 参数拥有默认值 utf-16le
    # 再设置为 utf8 便会导致上述错误
    
    try:
        conn = pyodbc.connect(
            "DRIVER={ODBC Driver 18 for SQL Server};"
            "SERVER=127.0.0.1,1433;"
            "DATABASE=TEST;"
            "UID=admin;"
            "PWD=admin;"
            "TrustServerCertificate=yes;"
            "Mars_Connection=yes;",
            encoding='utf-8',
            autocommit=True
        )
        print("连接成功!")
    except Exception as e:
        print("连接失败:", e)
    

    删除 encoding='utf-8' 即可,此时数据库链接恢复正常!!!

    对于sqlserver 来说,建议采用 utf-16le【默认值】,原文链接

相关文章:

  • Linux下用route命令修改默认网关,不用重启网络
  • 分布式系统和集群式系统
  • Spring Boot + MyBatis 实现 RESTful API 的完整流程
  • CSS—选择器详解:5分钟动手掌握选择器
  • LeetCode第57题_插入区间
  • eclipse SVN: ‘0x00400006:踩坑之旅
  • 【2025】企业信息查询接口解析
  • 陕西省地标-DB61/T 1121-2018 政务服务中心建设和运营规范
  • sam-vit-base 辅助检测卡车的可拽雨覆完全覆盖
  • leetcode_字典树 139. 单词拆分
  • 性能测试分析和调优
  • 【Linux】Linux的进程控制
  • Flutter系列教程之(8)——CheckBox多选框及动态更改多选框
  • VSCode大的JSON数据不能折叠问题
  • Spring Boot 消息队列(以RabbitMQ为例)
  • 【AI论文】MedVLM-R1:通过强化学习激励视觉语言模型(VLMs)的医疗推理能力
  • 基于STM32语音识别的智能家居
  • Redis分布式缓存面试题(2025.3.1更新)
  • Vue3.x 封装一个简单的日历
  • 《操作系统 - 清华大学》 9 -2:进程调度:调度原则
  • 有哪些网站可以做h5/免费发布推广的网站有哪些
  • 网站平台建设的当前问题/2024年阳性什么症状
  • 如何法院网站建设/百度推广登陆
  • 昆明做网站优化/新闻发稿
  • 天津市城市建设档案馆网站/seo具体seo怎么优化
  • 创建一个公司网站需要多少钱/宣传推广方案范文