我的环境与this
非常相似正确显示数据库中的所有非unicode数据。 我能够将一些数据保存到数据库(ascii和cyrillic)。然后正确显示标准的ascii字符,但是Cyrillic数据显示如下
РВР'ВР’Р'ВРВРІР
如何找到发生错误编码/解码操作的点?
答案 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文件在行的开头不应包含空格或制表符。 这些设置允许将西里尔符号正常插入数据库。