Подтвердить что ты не робот

Pyodbc/FreeTDS/unixODBC на Debian Linux: проблемы с версией TDS

У меня возникли проблемы с использованием pyodbc в Debian Lenny (5.0.7). В частности, я, кажется, испытываю проблемы с получением значений NVARCHAR (а не экспертом SQL Server, так что легко на меня:)).

Большинство традиционных запросов работают нормально. Например, количество строк в таблице1 дает

cursor.execute("SELECT count(id) from table1")
<pyodbc.Cursor object at 0xb7b9b170>
>>> cursor.fetchall()
[(27, )]

Как и полная дампа идентификаторов

>>> cursor.execute("SELECT id FROM table1")
<pyodbc.Cursor object at 0xb7b9b170>
>>> cursor.fetchall()
[(0.0, ), (3.0, ), (4.0, ), (5.0, ), (6.0, ), (7.0, ), (8.0, ), (11.0, ), (12.0, ), (18.0, ), (19.0, ), (20.0, ), (21.0, ), (22.0, ), (23.0, ), (24.0, ), (25.0, ), (26.0, ), (27.0, ), (28.0, ), (29.0, ), (32.0, ), (33.0, ), (34.0, ), (35.0, ), (36.0, ), (37.0, )]

Но свалка имен (опять же, типа NVARCHAR) не

>>> cursor.execute("SELECT name FROM table1")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
pyodbc.ProgrammingError: ('42000', '[42000] [FreeTDS][SQL Server]Unicode data in a Unicode-only collation or ntext data cannot be sent to clients using DB-Library (such as ISQL) or ODBC version 3.7 or earlier. (4004) (SQLExecDirectW)')

... критическая ошибка

pyodbc.ProgrammingError: ('42000', '[42000] [FreeTDS] [SQL Server] Данные Unicode в данных сравнения или только в Unicode не могут быть отправлены клиентам с использованием DB-библиотеки (например, ISQL ) или ODBC версии 3.7 или более ранней. (4004) (SQLExecDirectW) ')

Это согласовано между таблицами.

Я пробовал разные версии каждого из них, но теперь я запускаю unixODBC 2.2.11 (из lenny repos), FreeTDS 0.91 (построенный из источника, с ./configure --enable-msdblib --with-tdsver=8.0) и pyodbc 3.0.3 ( построенный из источника).

С подобной комбинацией (unixODBC 2.3.0, FreeTDS 0.91, pyodbc 3.0.3) тот же код работает в Mac OS X 10.7.2.

Я искал высоко и низко, исследуя представленные решения здесь и здесь и перекомпилировать разные версии unixODBC и FreeTDS, но все равно не кубики. Соответствующие файлы конфигурации приведены ниже:

[email protected]:~$ cat /usr/local/etc/freetds.conf
#$Id: freetds.conf,v 1.12 2007/12/25 06:02:36 jklowden Exp $
#
# This file is installed by FreeTDS if no file by the same 
# name is found in the installation directory.  
#
# For information about the layout of this file and its settings, 
# see the freetds.conf manpage "man freetds.conf".  

# Global settings are overridden by those in a database
# server specific section
[global]
        # TDS protocol version
        tds version = 8.0
        client charset = UTF-8

        # Whether to write a TDSDUMP file for diagnostic purposes
        # (setting this to /tmp is insecure on a multi-user system)
;       dump file = /tmp/freetds.log
;       debug flags = 0xffff

        # Command and connection timeouts
;       timeout = 10
;       connect timeout = 10

        # If you get out-of-memory errors, it may mean that your client
        # is trying to allocate a huge buffer for a TEXT field.  
        # Try setting 'text size' to a more reasonable limit 
        text size = 64512

# A typical Sybase server
[egServer50]
        host = symachine.domain.com
        port = 5000
        tds version = 5.0

# A typical Microsoft server
[egServer70]
        host = ntmachine.domain.com
        port = 1433
        tds version = 8.0

[foo]
        host = foo.bar.com
        port = 1433
        tds version = 8.0

[email protected]:~$ cat /etc/odbc.ini 
[foo]
Description     = Foo
Driver          = foobar
Trace           = No
Database        = db
Server          = foo.bar.com
Port            = 1433
TDS_Version     = 8.0
[email protected]:~$ cat /etc/odbcinst.ini 
[foobar]
Description     = Description
Driver          = /usr/lib/odbc/libtdsodbc.so
Setup           = /usr/lib/odbc/libtdsS.so
CPTimeout       =
CPReuse         =

Любые советы или указания будут очень оценены!

4b9b3361

Ответ 1

Я столкнулся с той же ошибкой с Ubuntu. Я "решил" его с работой. Все, что вам нужно сделать, это установить переменную окружения TDSVER.

import os
os.environ['TDSVER'] = '8.0'

Как я уже сказал, это не настоящее "решение", но оно работает.

Ответ 2

Попробуйте добавить

TDS_Version=8.0;ClientCharset=UTF-8

в строке подключения.

Например,

DRIVER=FreeTDS;SERVER=myserver;DATABASE=mydatebase;UID=me;PWD=pwd;TDS_Version=8.0;ClientCharset=UTF-8

Ответ 3

Не могли бы вы просто решить проблему и преобразовать или трансформировать name в то, что она может обрабатывать?

  

cursor.execute( "SELECT CAST (имя AS TEXT) FROM table" )