Why this error when getting data from MSSQL using pyodbc?(为什么在使用pyodbc从MSSQL获取数据时出现此错误?)
本文介绍了为什么在使用pyodbc从MSSQL获取数据时出现此错误?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在使用pyodbc从MSSQL检索数据,以下是我正在使用的代码:
import pyodbc
server = 'xxxxxxxxDEV'
database = 'SandBox'
username = 'zzzzzzz'
password = 'xxxxxxx'
driver = '{SQL Server}'
cnxn = pyodbc.connect('DRIVER='+driver+';PORT=4853;SERVER='+server+';PORT=4853;DATABASE='+database+';UID='+username+';PWD='+ password)
cursor = cnxn.cursor()
cursor.execute("select * from fieldscreenscheme ")
row = cursor.fetchone()
if row:
print row
这是我收到的错误消息:
cnxn = pyodbc.connect('DRIVER='+driver+';PORT=43853;SERVER='+server+';PORT=43853;DATABASE='+database+';UID='+username+';PWD='+ password)
pyodbc.Error: ('08001', '[08001] [Microsoft][ODBC SQL Server Driver][DBNETLIB]SQL Server does not exist or access denied. (17) (SQLDriverConnect); [01000] [Microsoft][ODBC SQL Server Driver][DBNETLIB]ConnectionOpen (Connect()). (53); [01S00] [Microsoft][ODBC SQL Server Driver]Invalid connection string attribute (0)')
我安装了ODBC驱动程序。有什么建议可以解决这个错误吗?
我看着这两个人,但没有帮我解决这个问题。
Python - Can't connect to MS SQL
pyodbc + MySQL + Windows: Data source name not found and no default driver specified
Microsoft文档:https://github.com/Microsoft/azure-docs/blob/master/articles/sql-database/sql-database-develop-python-simple.md
推荐答案
两个问题:
- 通常,一个人提供
INSTANCENAME
或端口号,而不是同时提供两者。 - SQL Server的ODBC连接字符串不使用
PORT=
,它们将端口号放在SERVER=
参数中,例如SERVER=xxxxxxxx,43853
。(请注意,实例名称被省略,并且分隔符是逗号,而不是冒号。)
这篇关于为什么在使用pyodbc从MSSQL获取数据时出现此错误?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:为什么在使用pyodbc从MSSQL获取数据时出现此错误?


基础教程推荐
猜你喜欢
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- 带更新的 sqlite CTE 2022-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01