我需要使用Python 2.7将unicode发送到SQL Server。我failed with pymssql。我现在正试图让pypyodbc
工作(而不是pyodbc
),因为它会working unicode examples。问题是示例中的连接字符串看起来不像我认识的任何东西。我查看this,经过一些试验和错误后,构造了这个字符串:
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成功连接它们。我错过了什么?
答案 0 :(得分:18)
从连接字符串的server
,uid
,pwd
和database
属性中删除单引号:
conn = pypyodbc.connect("DRIVER={SQL Server};SERVER=MyServer;UID=me;PWD=password;DATABASE=db")
由于pypyodbc
提及与pyodbc
的兼容性,请花一点时间查看pyodbc connection string docs和pyodbc.connect()示例。我在pyodbc中使用这个语法:
cnxn = connect(driver='{SQL Server}', server='localhost', database='test', uid='me', pwd='me2')
答案 1 :(得分:3)
在连接字符串中省略端口号(1433),从Linux客户端(但不是Windows 7)向我抛出错误。这可能是一个配置问题,但我没有时间去追逐它。
把它放在那里,以防它帮助其他人。