16

我在 Windows 7 上使用 ActivePython 2.7.2.5。

在尝试使用以下代码使用 pyodbc 模块连接到 sql-server 数据库时,我收到了后续的 Traceback。关于我做错了什么的任何想法?

代码:

import pyodbc
driver = 'SQL Server'
server = '**server-name**'
db1 = 'CorpApps'
tcon = 'yes'
uname = 'jnichol3'
pword = '**my-password**'

cnxn = pyodbc.connect('DRIVER={SQL Server};SERVER=server;DATABASE=db1;UID=uname;PWD=pword;Trusted_Connection=yes')
cursor = cnxn.cursor()
cursor.execute("select * from appaudit_q32013")
rows = cursor.fetchall()
for row in rows:
    print row

追溯:

Traceback (most recent call last):
  File "pyodbc_test.py", line 9, in <module>
    cnxn = pyodbc.connect('DRIVER={SQL Server};SERVER=server;DATABASE=db1;UID=uname;PWD=pword;Trusted_Connection=yes')
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)')
4

6 回答 6

27

您正在使用 的连接字符串'DRIVER={SQL Server};SERVER=server;DATABASE=db1;UID=uname;PWD=pword;Trusted_Connection=yes',您正在尝试连接到名为 的服务器、名为server的数据库db1等。它不使用您之前设置的变量,它们没有被使用。

可以将连接字符串参数作为关键字参数传递给connect函数,因此您可以使用:

cnxn = pyodbc.connect(driver='{SQL Server}', host=server, database=db1,
                      trusted_connection=tcon, user=uname, password=pword)
于 2013-09-17T22:28:44.097 回答
12

我有同样的错误消息,在我的情况下,问题是 [SQL Server] 驱动程序需要 TLS 1.0,它在我的服务器上被禁用。更改为较新版本的 SNAC,SQL Server Native Client 11.0解决了该问题。

所以我的连接字符串看起来像:

cnxn = pyodbc.connect(driver='{SQL Server Native Client 11.0}', 
                      host=server, database=db1, trusted_connection=tcon,
                      user=uname, password=pword)
于 2016-07-08T15:59:20.193 回答
3

由于另一个原因,我遇到了这个错误。
这是因为我的服务器除了地址之外还有一个“端口”。
我可以通过将以下值分配给连接字符串的“Server”参数来解决这个问题。

"...;Server=<server_name>,<port#>;..."

请注意,它是“逗号”而不是“冒号”/“句号”

于 2017-03-23T15:15:50.893 回答
0

两种方法都存在不同的安全风险。如果您使用 Sql Server 身份验证,则会在代码中公开您的用户名/密码。但至少您使用相同的凭据进行处理。如果您使用 Windows 身份验证,则必须确保所有可能的用户都在 Sql 服务器中设置了正确的权限。使用 Sql 身份验证,您只能设置一个用户,但多个人可以明智地使用该一个 Sql 用户权限。

于 2016-02-18T01:58:26.200 回答
0

我今天有同样的问题。我在连接字符串中使用了 localhost 。通过将 localhost 替换为“服务器名称”来解决此问题。我的数据库和应用程序在同一台机器上运行。

如果您没有服务器名称,请转到 Sql server management studio 并执行以下查询,这将为您提供服务器名称。

SELECT @@SERVERNAME

连接字符串如下所示

conn = pyodbc.connect('Driver={SQL Server};'
                      'Server=myServerName;'
                      'Database=mydb;'
                      'Trusted_Connection=yes;')
于 2021-03-14T13:23:43.160 回答
0
cnxn = pyodbc.connect(driver='{SQL Server}', host=server, database=db1,
                       user=uname, password=pword)

print(cnxn)

我删除了“Trusted_Connection”部分,它对我有用。

于 2022-02-02T12:27:10.560 回答