ubuntu mysql 客户端 emma 中文乱码问题解决

7 篇文章 0 订阅
emma默认用apt-get 安装的话,emma是不支持中文的,配置文件或直接修改emma程序源文件(python)。

apt-get安装emma

[list=1]
sudo apt-get install emma
[/list]

如果你已经安装完毕并且运行过emma,程序就会创建 ~/.emma/emmarc文件,保存配置。所以可以更改这里的配置文件,或者像下面直接修改emma的python源文件。

[list=1]
vim ~/.emma/emmarc
[/list]
找到

[list=1]
db_encoding=latin1
[/list]
改为

[list=1]
db_encoding=utf8
[/list]

重新运行emma,此时发现还是乱码,在执行所有的sql语句之前加入这条sql语句,

[b]set[/b] names utf8

按ctrl+enter执行之后,ok!


但每次新用户都要改配置文件,以及执行新sql前都加这个语句,岂不是很费力,直接修改emma的源文件,来实现,新创建的emmrc配置文件就是utf8,和当选择数据库时,自动的执行“set names utf8” 语句。


ubuntu的apt-get 安装emma是在/usr/share/emma目录下面。

[list=1]
cd /usr/share/emma/emmalib
[*]sudo vim __init__.py

[/list]
找到

[list=1]
"db_encoding": "latin1"
[/list]
改为

"db_encoding": "utf8"

保存退出。以后新创建的配置文件默认就会是utf8的解码了,我想在连接数据之后就执行 “set names utf8” 语句,所以

[list=1]
sudo vim /usr/share/emma/emmalib/mysql_host.py
[/list]
跳到155行左右的_use_db(self, name, do_query=True)函数哪里,改成如下

[b]def[/b] _use_db(self, name, do_query=True):
[*] [b]if[/b] self.current_db [b]and[/b] name == self.current_db.name: [b]return[/b]

[b]if[/b] do_query:
[*] self.query("use `%s`" % name, False)

[b] self.query("set names utf8", False) [/b]
[*] [b]try[/b]:

self.current_db = self.databases[name]
[*] [b]except[/b] KeyError:

[b]print[/b] "Warning: used an unknown database %r! please refresh host!\n%s" % (name, "".join(traceback.format_stack()))


……
……
……
更多内容已迁移至新博客:[url=http://www.adintellig.com/]Manny很忙[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值