Подключение к SQL Server с помощью pypyodbc

Мне нужно отправить unicode на SQL Server с помощью Python 2.7. Я не удалось использовать pymssql. Сейчас я пытаюсь заставить работать pypyodbc (в отличие от pyodbc), поскольку он дает работу примеры юникода. Проблема в том, что строка подключения в примере не похожа ни на что, что я узнаю. Я просмотрел это и, немного проб и ошибок, построил эту строку:

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. Что мне не хватает?


person scharfmn    schedule 15.04.2013    source источник


Ответы (2)


Удалите одинарные кавычки из атрибутов server, uid, pwd и database строки подключения:

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')
person Bryan    schedule 15.04.2013

Отсутствие номера порта (1433) в строке подключения вызвало у меня ошибки клиента Linux (но не Windows 7). Вероятно, это проблема конфигурации, но у меня не было времени заниматься этим.

Разместите это там, на случай, если это поможет кому-то еще.

person peter n    schedule 12.06.2015