使用pyodbc错误

时间:2017-03-23 22:11:37

标签: python sql-server pyodbc

我正在使用pyodbc从MSSQL中检索数据,这是我正在使用的代码:

import pyodbc
server = 'xxxxxxxx\DEV'
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

3 个答案:

答案 0 :(得分:2)

两个问题:

  1. 通常,提供 \INSTANCENAME 端口号,而不是两者。
  2. SQL Server的ODBC连接字符串不使用PORT=,它们将端口号放在SERVER=参数中,例如SERVER=xxxxxxxx,43853。 (请注意,实例名称被省略,分隔符是逗号,而不是冒号。)

答案 1 :(得分:0)

我遇到了同样的问题并修改了更改连接字符串,如下所示。 写

driver = '{ODBC Driver 13 for SQL Server}'

而不是

driver = '{SQL Server}'

答案 2 :(得分:0)

我整天都面临着相同的问题,我尝试了所有可能的ODBC Driver for SQL Server,这是列表,我一个接一个地尝试,对我有用

Driver={ODBC Driver 11 for SQL Server} for SQL Server 2005 - 2014
Driver={ODBC Driver 13 for SQL Server} for SQL Server 2005 - 2016
Driver={ODBC Driver 13.1 for SQL Server} for SQL Server 2008 - 2016
Driver={ODBC Driver 17 for SQL Server} for SQL Server 2008 - 2017

这些是我们可以使用的其他一些,在我看来,最后一个可以用:)

Driver={SQL Server} for SQL Server 2000
Driver={SQL Native Client} for SQL Server 2005
Driver={SQL Server Native Client 10.0} for SQL Server 2008
Driver={SQL Server Native Client 11.0} for SQL Server 2012