1. 程式人生 > >ubuntu emma 中文亂碼解決方案

ubuntu emma 中文亂碼解決方案

在Linux如果使用mysql的圖形客戶端,我感覺Emma算一個好用的了。

比起mysql自己的Mysql Query Browser 要好, 而且最不能忍受的是Mysql Query Browser 在Ubuntu 11.10 會有程式崩潰現象。

相比而言emma是挺好,但是emma預設用apt-get 安裝的話,emma是不支援中文的,這個需要自己修改一下了配置檔案,或者直接修改emma程式原始檔了(emma 用python編寫的)。

apt-get安裝emma

  1. sudo apt-get install emma  

如果你已經安裝完畢並且執行過emma,程式就會建立 ~/.emma/emmarc檔案,儲存你自己的一些配置。所以可以更改這裡的配置檔案,或者像下面直接修改emma的python原始檔。

  1. vim ~/.emma/emmarc   

找到

  1. db_encoding=latin1  
改為
  1. db_encoding=utf8  
然後裡,重新執行emma,此時發現還是亂碼,不要著急,在執行所有的sql語句之前加入這條sql語句,
  1. set names utf8  
按ctrl+enter執行之後,再看看是不是已經ok了。正常顯示中文了。(這裡還有一個前提是你的資料庫都是utf8編碼的喲)

好了,但是每次新使用者都要改配置檔案,以及執行新sql前都加這個語句,豈不是很費力。而自己有很懶,並且我的資料庫大部分都是utf8的,所以直接修改emma的原始檔,來實現,新建立的emmrc配置檔案就是utf8,和當選擇資料庫時,自動的執行“set names utf8” 語句。

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

  1. cd /usr/share/emma/emmalib  
  2. sudo vim __init__.py  
找到
  1. "db_encoding": "latin1"  
改為
  1. "db_encoding": "utf8"  
儲存退出。以後新建立的配置檔案預設就會是utf8的解碼了,我想在連線資料之後就執行 “set names utf8” 語句,所以
  1. sudo vim /usr/share/emma/emmalib/mysql_host.py  
跳到155行左右的_use_db(self, name, do_query=True)函式哪裡,改成如下
  1. def _use_db(self, name, do_query=True):  
  2.         if self.current_db and name == self.current_db.name: return  
  3.         if do_query:   
  4.                 self.query("use `%s`" % name, False)  
  5.                 self.query("set names utf8",  False)  
  6.         try:  
  7.                 self.current_db = self.databases[name]  
  8.         except KeyError:  
  9.                 print "Warning: used an unknown database %r! please refresh host!\n%s" % (name, "".join(traceback.format_stack()))  
自己看著改,反正改成上面的樣子,注意空格,因為python是以空格當語句的分割語法的。

其實就是加了一句

  1. self.query("set names utf8",  False
轉載【http://www.linuxidc.com/Linux/2011-11/47167.htm】