Archive for the 'SQLObject' Category

SQLObject加MySQL的 utf-8解决之道

SQLObject对utf-8的支持一直为很多人所诟病,MySQL对utf-8的支持
在mysqlconnection.py中可以看到SQLObject连接MySQL时的一些细节,
__init__中支持额外的几个参数

  1. self.need_unicode = False
  2.         for key in ("unix_socket", "init_command",
  3.                 "read_default_file", "read_default_group"):
  4.             if key in kw:
  5.                 self.kw[key] = col.popKey(kw, key)
  6.         for key in ("connect_timeout", "compress", "named_pipe", "use_unicode",
  7.                 "client_flag", "local_infile"):
  8.             if key in kw:
  9.                 self.kw[key] = int(col.popKey(kw, key))
  10.         if "charset" in kw:
  11.             self.dbEncoding = self.kw["charset"] = col.popKey(kw, "charset") 
  12.         else:
  13.             self.dbEncoding = None
  14.         if "sqlobject_encoding" in kw:
  15.             self.encoding = col.popKey(kw, "sqlobject_encoding")
  16.         else:
  17.             self.encoding = 'ascii'
  18.         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

合起来便是:

  1. "mysql://username:password@host/db_name?sqlobject_encoding=utf-8&read_default_file=my.cnf"

之后SQLObject便会很好的处理来自MySQL的utf-8字符串了
当然不能忘了在my.ini中添加默认链接所使用的字符编码:

  1. [client]
  2. default-character-set = utf8
Creative Commons License
This work is licensed under a Creative Commons License.