Подключение к MSSQL Server с помощью pypyodbc на OS X
У меня проблемы с установлением базового соединения с сервером баз данных MSSQL с использованием pypyodbc в OS X.
Я установил оба unixodbc
а также freetds
через доморощенный
brew install unixodbc
brew install freetds
Я тогда установил pypyodbc
mkvirtualenv test
pip install pypyodbc
Когда я пытаюсь установить соединение, оно терпит неудачу с:
$ python -i test.py
Traceback (most recent call last):
File "test.py", line 20, in <module>
c = p.connect(dsn)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 2434, in __init__
self.connect(connectString, autocommit, ansi, timeout, unicode_results, readonly)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 2483, in connect
check_success(self, ret)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 988, in check_success
ctrl_err(SQL_HANDLE_DBC, ODBC_obj.dbc_h, ret, ODBC_obj.ansi)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 966, in ctrl_err
raise DatabaseError(state,err_text)
pypyodbc.DatabaseError: (u'01000', u"[01000] [unixODBC][Driver Manager]Can't open lib 'SQL Server' : file not found")
>>>
Мой основной test.py
выглядит так:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import pypyodbc as p
settings = {
"driver": "FreeTDS",
"hostname": "mssql.local",
"username": "testuser",
"password": "testpass",
"database": "testdb",
"port": 1433
}
dsn = "DRIVER={{{driver:s}}};SERVER={hostname:s};PORT={port:d};DATABASE={database:s};UID={username:s};PWD={password:s};CHARSET=UTF8;TDS_Version=8.0".format(**settings) # noqa
c = p.connect(dsn)
xs = c.execute("SELECT name FROM master..sysdatabases").fetchall()
Есть несколько похожих вопросов, но они, похоже, не решают проблему, с которой я столкнулся, которая, кажется, связана с проблемой драйвера.
$ python -i test.py
Username: IRMA_RO
Password:
Traceback (most recent call last):
File "test.py", line 15, in <module>
c = p.connect("DSN=na-dev;UID={0:s};PWD={1:s}".format(username, password))
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 2434, in __init__
self.connect(connectString, autocommit, ansi, timeout, unicode_results, readonly)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 2483, in connect
check_success(self, ret)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 988, in check_success
ctrl_err(SQL_HANDLE_DBC, ODBC_obj.dbc_h, ret, ODBC_obj.ansi)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 975, in ctrl_err
err_list.append((from_buffer_u(state), from_buffer_u(Message), NativeError.value))
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/site-packages/pypyodbc.py", line 482, in UCS_dec
uchar = buffer.raw[i:i + ucs_length].decode(odbc_decoding)
File "/Users/xxxxxxxx/.virtualenvs/symplectic_cleanup/lib/python2.7/encodings/utf_32.py", line 11, in decode
return codecs.utf_32_decode(input, errors, True)
UnicodeDecodeError: 'utf32' codec can't decode bytes in position 0-1: truncated data
>>>
Кажется, здесь сообщается об ошибке, связанной с этим: https://code.google.com/p/pypyodbc/issues/detail?id=31
1 ответ
Я не уверен, что вы решили свою проблему, но я просто боролся с подобной проблемой и исправил ее. Я получаю ту же ошибку "utf32" не может декодировать байты в позиции 0-1: усеченные данные "ошибка.
Необходимо дважды проверить, что в файле odbc.ini имя сервера для раздела совпадает с именем в файле freetds.conf.
Например:
odbc.ini
[old_flood]
Driver = FreeTDS
Description = RTS Old Flood
ServerName = old_flood <----- this must be the same as the name in freetds.conf
freetds.conf
[old_flood] <----- This is the same as the ServerName above
host = <server ip address>
port = <server port>
tds version = 8.0
В любом случае, надеюсь, это поможет.
-------- Дополнительная информация -------- Вам также необходимо убедиться, что созданный вами пользователь БД имеет надлежащий доступ к базе данных, в которую вы пытаетесь читать / писать. Мне просто нужен был доступ для чтения. Вы устанавливаете это в узле безопасности в SQL Server Management Studio. Щелкните правой кнопкой мыши на пользователе, затем перейдите к User Mapping. Проверьте соответствующие базы данных, не забудьте выделить базу данных, а затем внизу установите роль базы данных.