creamidea / Mushroom

To display Node Capture Data and Control it
Other
0 stars 1 forks source link

Python在Linux上连接SQL Server出现中文乱码 #68

Open creamidea opened 10 years ago

creamidea commented 10 years ago

SQL Server 字符编码默认,中文版

对于我来说失败方式: 在SQL语句中加上N 比如:

string insertSql = "Insert into UserInfo (UserName) Values ('"+userName.Text.Trim()+" ' )";

第二种方式,在连接时设定字符为utf8,在构造语句时将字符以utf8编码

self.conn = pymssql.connect(host=self.host,user=self.user,password=self.pwd,database=self.db,charset="utf8")

insertSql = "insert into WeiBo([UserId],[WeiBoContent],[PublishDate]) values(1,'测试','2012/2/1')".encode("utf8")

第三种,/etc/freetds/freetds.conf

[global]
    client charset = UTF-8

第四种,我一直以为是系统编码造成的。

于是去查询了一下关于系统设置的方式

1.    LC_COLLATE
定义该环境的排序和比较规则
2.    LC_CTYPE
用于字符分类和字符串处理,控制所有字符的处理方式,包括字符编码,字符是单字节还是多字节,如何打印等。是最重要的一个环境变量。
3.    LC_MONETARY
货币格式
4.    LC_NUMERIC
非货币的数字显示格式
5.    LC_TIME
时间和日期格式
6.    LC_MESSAGES
提示信息的语言。另外还有一个LANGUAGE参数,它与LC_MESSAGES相似,但如果该参数一旦设置,则LC_MESSAGES参数就会失效。LANGUAGE参数可同时设置多种语言信息,如LANGUANE="zh_CN.GB18030:zh_CN.GB2312:zh_CN"。
7.    LANG
LC_*的默认值,是最低级别的设置,如果LC_*没有设置,则使用该值。类似于 LC_ALL。
8.    LC_ALL
它是一个宏,如果该值设置了,则该值会覆盖所有LC_*的设置值。注意,LANG的值不受该宏影响。

首先,需要安装中文包:

$ sudo apt-get install language-pack-hans-zh-hans
$ sudo apt-get install language-pack-hans-zh-hans-base

之后就是设置系统的字符编码

$ export LC_ALL = zh_CN.UTF-8

其实常用的就是那几个命令

$ locales
$ locale-gen
$ sudo dpkg-reconfigure locales

常用的几个文件 /etc/sysconfig/i18n /etc/environment /usr/lib/locale/ /var/lib/locales/supported.d/local /var/lib/locales/supported.d/local /etc/default/locale

关于Linux中文环境的设置

Linux下FreeTDS连接SQLServer乱码问题解决方法

向Sql Server数据库插入中文时显示乱码的解决办法