今天登陸一臺好久沒有登陸的服務器執行一條 SQL,發現輸入中文所有變成亂碼了。html
服務器的版本是 Ubuntu 16.04,以前借給朋友裝過 Confluence 之類的軟件測試,不知道是否是跟這個問題有關。ubuntu
無論,先執行如下命令:服務器
export LANG='zh_CN.UTF-8' export LC_ALL='zh_CN.UTF-8'
執行後仍是不行。網上搜了搜,找到這篇文章:解決ubunut系統locale: Cannot set LC_CTYPE to default locale: No such file or directory,看起來不錯,最終確實解決了個人問題。測試
mkdir -p /var/lib/locales/supported.d/ cp /usr/share/i18n/SUPPORTED /var/lib/locales/supported.d/local cd /var/lib/locales/supported.d/ cat local |grep "en_US.UTF-8 UTF-8" > 1.txt cat local |grep "zh_CN.UTF-8 UTF-8" >> 1.txt rm -rf local && mv 1.txt local locale-gen --purge locale
這時候應該就行了,不過仍是要先檢查一下 locale
命令的輸出。
若是執行發現 LC_ALL
的值仍是有問題(我這裏爲空),則執行:.net
export LC_ALL=zh_CN.UTF-8
至此,問題解決。code
這樣的方式實際上是讓系統的語言變成中文。而以前默認是英文的,且中文也沒有亂碼,更優的方案須要進一步研究。htm
原文地址: CroWall Notesblog