博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
emma中文显示乱码问题解决
阅读量:5076 次
发布时间:2019-06-12

本文共 1337 字,大约阅读时间需要 4 分钟。

  在Linux中如果使用mysql的图形客户端,个人感觉Emma还不错。但是emma默认用apt-get 安装的话,emma是不支持中文的,这个需要自己修改一下了配置文件,或者直接修改emma程序源文件了(emma 用python编写的)。

  apt-get安装emma

  Java代码

  sudo apt-get install emma

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

  Java代码

  vim ~/.emma/emmarc

  找到  db_encoding=latin1 改为  db_encoding=utf8  然后重新运行emma,此时发现还是乱码,不要着急,在执行所有的sql语句之前加入这条sql语句:

  Java代码

  set names utf8

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

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

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

  Java代码

  cd /usr/share/emma/emmalib

  sudo vim __init__.py

  找到  "db_encoding": "latin1"  改为 "db_encoding": "utf8"

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

  Java代码

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

  跳到155行左右的_use_db(self, name, do_query=True)函数哪里,(对照着加。。。)

  Java代码

  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]

  自己看着改,反正改成上面的样子,注意空格,因为python是以空格当语句的分割语法的。到这里就彻底ok了。

转载于:https://www.cnblogs.com/chenjianhong/p/4144627.html

你可能感兴趣的文章
洛谷 P2089 烤鸡【DFS递归/10重枚举】
查看>>
15 FFT及其框图实现
查看>>
Linux基本操作
查看>>
osg ifc ifccolumn
查看>>
C++ STL partial_sort
查看>>
3.0.35 platform 设备资源和数据
查看>>
centos redis 安装过程,解决办法
查看>>
IOS小技巧整理
查看>>
WebDriverExtensionsByC#
查看>>
我眼中的技术地图
查看>>
lc 145. Binary Tree Postorder Traversal
查看>>
sublime 配置java运行环境
查看>>
在centos上开关tomcat
查看>>
重启rabbitmq服务
查看>>
正则表达式(进阶篇)
查看>>
无人值守安装linux系统
查看>>
【传道】中国首部淘宝卖家演讲公开课:农业本该如此
查看>>
jQuery应用 代码片段
查看>>
MVC+Servlet+mysql+jsp读取数据库信息
查看>>
黑马程序员——2 注释
查看>>