sqlobject mysql_[转]SQLObject加MySQL的 utf-8解决之道

lhwork 发表于 2007-2-1 21:17:57

SQLObject对utf-8的支持一直为很多人所诟病,MySQL对utf-8的支持

在mysqlconnection.py中可以看到SQLObject连接MySQL时的一些细节,

__init__中支持额外的几个参数 self.need_unicode = False

for key in ("unix_socket", "init_command",

"read_default_file", "read_default_group"):

if key in kw:

self.kw[key] = col.popKey(kw, key)

for key in ("connect_timeout", "compress", "named_pipe", "use_unicode",

"client_flag", "local_infile"):

if key in kw:

self.kw[key] = int(col.popKey(kw, key))

if "charset" in kw:

self.dbEncoding = self.kw["charset"] = col.popKey(kw, "charset")

else:

self.dbEncoding = None

if "sqlobject_encoding" in kw:

self.encoding = col.popKey(kw, "sqlobject_encoding")

else:

self.encoding = 'ascii'

DBAPI.__init__(self, **kw)

其中的read_default_file和sqlobject_encoding会对SQLObject返回结果的编码产生

影响,

sqlobject_encoding 指明返回对象的编码

read_default_file 则指明连接时读取的客户端配置文件,不同平台该文件名字有可能

不一样,比如my.cnf或者my.ini

也就是说,使用MySQL时,需要支持utf-8的话,需要给连接字符串增加如下额外的参数:

sqlobject_encoding=utf-8&read_default_file=my.cnf

合起来便是: "mysql://username:password@host/db_name?sqlobject_encoding=utf-8&read_default_file=my.cnf"

之后SQLObject便会很好的处理来自MySQL的utf-8字符串了

当然不能忘了在my.ini中添加默认链接所使用的字符编码:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值