通过unixODBC和FreeTDS将{syrillic符号保存到MSSQL的问题

时间:2015-11-02 07:42:18

标签: django pyodbc freetds unixodbc

我的环境与this

非常相似

正确显示数据库中的所有非unicode数据。 我能够将一些数据保存到数据库(ascii和cyrillic)。然后正确显示标准的ascii字符,但是Cyrillic数据显示如下

  

РВР'ВР’Р'ВРВРІР

如何找到发生错误编码/解码操作的点?

1 个答案:

答案 0 :(得分:1)

我终于解决了一个问题。 settings.py文件中的正确数据库配置是:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'db',
        'USER': 'user',
        'PASSWORD': 'pass',
        'HOST': '192.168.11.11',
        'PORT': '3306',
    },
    'mssql': {
        'ATOMIC_REQUESTS': True,
        'NAME': 'DB',
        'ENGINE': 'django_pyodbc',
        'USER': 'admin',
        'PASSWORD': 'pass',
        'OPTIONS': {
            'dsn': 'DBDSN',
            'host_is_server': True,
            'collation': 'Cyrillic_General_CI_AS',
            'driver_supports_utf8': True,
            'unicode_results':  True,
            'autocommit': True,
        },
    }
}

/etc/freetds/freetds.conf

[global]
tds version = 7.3
text size = 64512

[SRV]
host = mssql.local
port = 1433

/etc/odbc.ini

[ODBC Data Sources]
DBDSN = Microsoft SQL Server

[DBDSN]
Driver = FreeTDS
Servername = SRV
Trace = No
Database = DB

/etc/odbcinst.ini

[FreeTDS]
Description = FreeTDS
Driver = /usr/lib/x86_64-linux-gnu/odbc/libtdsodbc.so
Setup = /usr/lib/x86_64-linux-gnu/odbc/libtdsS.so
UsageCount = 1

重要的一点是,odbc.ini和odbsinst.ini文件在行的开头不应包含空格或制表符。 这些设置允许将西里尔符号正常插入数据库。