10

我需要使用 Python 2.7 将 unicode 发送到 SQL Server。我用 pymssql 失败了。我现在正在尝试开始pypyodbc工作(而不是pyodbc),因为它提供了工作 unicode 示例。问题是示例中的连接字符串看起来不像我认识的任何东西。我看着这个,经过一些试验和错误,构造了这个字符串:

conn = pypyodbc.connect("DRIVER={SQL Server};SERVER='MyServer';UID='me';PWD='MyPassword';DATABASE='db'")

重新DatabaseError关注连接字符串:

C:\Anaconda\lib\site-packages\pypyodbc.pyc in __init__(self, connectString, autocommit, ansi, timeout, unicode_results, readonly, **kargs)
---> 2 conn = pypyodbc.connect("DRIVER={SQL Server};SERVER='MyServer';UID='me';PWD='password';DATABASE='db'")

C:\Anaconda\lib\site-packages\pypyodbc.pyc in __init__(self, connectString, autocommit, ansi, timeout, unicode_results, readonly, **kargs)
---> 2273         self.connect(connectString, autocommit, ansi, timeout, unicode_results, readonly)

C:\Anaconda\lib\site-packages\pypyodbc.pyc in connect(self, connectString, autocommit, ansi, timeout, unicode_results, readonly)
---> 2321         check_success(self, ret)

C:\Anaconda\lib\site-packages\pypyodbc.pyc in ctrl_err(ht, h, val_ret, ansi)
---> 919                 raise DatabaseError(state,err_text)

DatabaseError: (u'08001', u'[08001] [Microsoft][ODBC SQL Server Driver][DBNETLIB]SQL Server does not exist or access denied.')

我知道我的凭据是正确的,因为我已经使用它们通过 pymssql 成功连接。我错过了什么?

4

2 回答 2

20

server从连接字符串的、uidpwddatabase属性中删除单引号:

conn = pypyodbc.connect("DRIVER={SQL Server};SERVER=MyServer;UID=me;PWD=password;DATABASE=db")

由于pypyodbc提到了与 的兼容性pyodbc,请花一点时间查看pyodbc 连接字符串文档pyodbc.connect()示例。我在 pyodbc 中使用这种语法:

cnxn = connect(driver='{SQL Server}', server='localhost', database='test', uid='me', pwd='me2')
于 2013-04-15T21:31:18.800 回答
3

在连接字符串中省略端口号 (1433),从 Linux 客户端(但不是 Windows 7)向我抛出了错误。这可能是一个配置问题,但我没有时间去追它。

把它放在那里,以防它帮助别人。

于 2015-06-12T14:42:50.250 回答