我需要使用Python 2.7将unicode发送到SQL Server。I 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成功连接。我遗漏了什么?
发布于 2013-04-16 05:31:19
删除连接字符串的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')发布于 2015-06-12 22:42:50
在连接字符串中省略了端口号(1433),从Linux客户端(而不是Windows7)向我抛出错误。这可能是一个配置问题,但我没有时间去追逐它。
把这个放出来,以防对别人有帮助。
https://stackoverflow.com/questions/16024956
复制相似问题