emma mysql_mysql图形客户端Emma简析

Emma是一款优于Mysql Query Browser的MySQL图形客户端,但在Ubuntu 11.10中默认不支持中文。要解决这个问题,可以通过修改~/.emma/emmarc配置文件将db_encoding改为utf8,或直接编辑Emma的Python源文件。此外,通过修改_host.py文件,可以在连接数据库后自动执行“set names utf8”以确保正常显示中文。
摘要由CSDN通过智能技术生成

在如果使用mysql的图形客户端,我感觉Emma算一个好用的了。比起mysql自己的Mysql Query Browser 要好, 而且最不能忍受的是Mysql Query Browser 在Ubuntu 11.10 会有程序崩溃现象。相比而言emma是挺好,但是emma默认用apt-get 安装的话,emma是不支持中文的,

在如果使用mysql的图形客户端,我感觉Emma算一个好用的了。

比起mysql自己的Mysql Query Browser 要好, 而且最不能忍受的是Mysql Query Browser 在Ubuntu 11.10 会有程序崩溃现象。

相比而言emma是挺好,但是emma默认用apt-get 安装的话,emma是不支持中文的,这个需要自己修改一下了配置文件,或者直接修改emma程序源文件了(emma 用python编写的)。

apt-get安装emma

sudo apt-get install emma

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

vim ~/.emma/emmarc

找到  www.2cto.com

db_encoding=latin1

改为

db_encoding=utf8

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

set names utf8

按ctrl+enter执行之后,再看看是不是已经ok了。正常显示中文了。(这里还有一个前提是你的都是utf8编码的哟)

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

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

cd /usr/share/emma/emmalib

sudo vim __init__.py

找到

"db_encoding": "latin1"

改为

"db_encoding": "utf8"

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

sudo vim /usr/share/emma/emmalib/_host.py

跳到155行左右的_use_db(self, name, do_query=True)函数哪里,改成如下

def _use_db(self, name, do_query=True):

if self.current_db and name == self.current_db.name: return

if do_query:

self.query("use `%s`" % name, False)

self.query("set names utf8",  False)

try:

self.current_db = self.databases[name]

except KeyError:

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

自己看着改,反正改成上面的样子,注意空格,因为python是以空格当语句的分割语法的。

其实就是加了一句

self.query("set names utf8",  False)

到这里就彻底ok了。

作者 piaoliuxiong

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值