emma中文显示乱码问题解决
来源:互联网 发布:mac无法识别u盘启动盘 编辑:程序博客网 时间:2024/06/05 03:39
在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了。
- emma中文显示乱码问题解决
- ubuntu mysql emma中文乱码问题解决
- ubuntu mysql客户端emma中文乱码问题解决
- ubuntu emma 中文乱码解决方案
- vi 中文显示乱码-问题解决
- notepad++中文显示乱码问题解决
- vim 中文显示乱码问题解决
- SecureCRT中文显示乱码问题解决
- 【问题解决】MYSQL中文显示'?'中文乱码问题
- Rhythmbox中文乱码显示的问题解决
- chm文件的中文显示乱码问题解决
- 用Ext显示页面中文乱码问题解决
- keil中文注释乱码显示问题解决方法
- CCS5.2 中文显示乱码问题解决方法
- MenuItem 显示中文乱码问题解决方案
- chm文件的中文显示乱码问题解决
- CCS5.2 中文显示乱码问题解决方法
- mysql 数据库显示中文乱码问题解决
- 关于JAVA中URL传递中文参数,取值是乱码的解决办法
- Leetcode:205. Isomorphic Strings(JAVA)
- JAVA学习【10】JVM基础知识整理
- Android Studio导出Jar包
- 转载一篇写的不错的java ClassLoader工作机制的文章
- emma中文显示乱码问题解决
- 什么是通用项目周期?它有什么样的特点?对其它项目有什么启示?
- 【版本发布】JEECG 3.6.2 移动能力版发布,快速开发平台
- ubuntu 各种软件安装和使用
- 快速排序 约瑟夫问题 顺序查找 二分查找
- gdb debug指令介绍
- 杀京东价格监控软件项目开发日志
- Linux编程(多线程编程)
- 修改xib里的控件位置大小