温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何理解mysql图形客户端Emma

发布时间:2021-11-03 09:11:28 来源:亿速云 阅读:183 作者:柒染 栏目:数据库

今天就跟大家聊聊有关如何理解mysql图形客户端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了。

看完上述内容,你们对如何理解mysql图形客户端Emma有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI