本站首页    管理页面    写新日志    退出


«September 2025»
123456
78910111213
14151617181920
21222324252627
282930


公告
 本博客在此声明所有文章均为转摘,只做资料收集使用。

我的分类(专题)

日志更新

最新评论

留言板

链接

Blog信息
blog名称:
日志总数:1304
评论数量:2242
留言数量:5
访问次数:7608794
建立时间:2006年5月29日




[Python]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中添加默认链接所使用的字符编码: [client]default-character-set = utf8


阅读全文(6768) | 回复(0) | 编辑 | 精华
 



发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)



站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.310 second(s), page refreshed 144760861 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号