程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> emma中文顯示亂碼問題解決

emma中文顯示亂碼問題解決

編輯:MySQL綜合教程

emma中文顯示亂碼問題解決   在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了。  

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved