(2013-01-13 17:15:16)
最近正在學習mysql,安裝環境是windows server 2003 32位操作系統+mysql 5.1.47
同時也安裝了mysql命令行以及mysql workbench最近正在學習mysql,安裝環境是windows server 2003 32位操作系統+mysql 5.1.47
這裏是test數據庫
create
table fortest(empno intauto_increment,empname nvarchar(20) not null,constraint pk_fortestprimary key(empno))default charset=utf8;
然後插入了一條數據
set names character utf8;
insert into fortest(empno)values('歐陽菲菲');
發現插入不了,總是報錯,具體錯誤如下:
這種情況主要是由於默認編碼設置錯誤引起的。
現在就查看一下mysql服務器的配置情況吧。
具體命令就是
show variables like 'character%';
查出的結果如下:
具體解決方法:
對於mysqlworkbench中的查詢出現中文亂碼主要是由於mysql服務器的配置中默認設置的編碼不是utf8引起的,具體在windows操作系統下,要修改mysql安裝目錄下的my.ini
(linux下則是安裝目錄下的my.cnf文件)
主要修改的部分如下:
[client]
port=3306
[mysql]
default-character-set=utf8
[mysqld]
# The TCP/IP Port the MySQL Server will listen on
port=3306
#Path to installation directory. All paths are usually resolvedrelative to this.
basedir="D:/Program Files/MySQL/MySQL Server 5.1/"
#Path to the database root
datadir="D:/MySQL/MySQL Server 5.1/Data/"
# The default character set that will be used when a new schema ortable is
# created and no character set is defined
default-character-set=utf8
具體修改的部分就是紅色粗體字的文字部分。
然後插入了一條數據
set names character utf8;
insert into fortest(empno)values('歐陽菲菲');
發現插入不了,總是報錯,具體錯誤如下:
這種情況主要是由於默認編碼設置錯誤引起的。
現在就查看一下mysql服務器的配置情況吧。
具體命令就是
show variables like 'character%';
查出的結果如下:
具體解決方法:
使用MySQL命令行可以實現許多我們需要的功能,不過在使用MySQL命令行的時候,有一個問題是在MySQL命令行插入中文數據或者查詢中文數據時出現亂碼,或者顯示不對。
在MySQL命令行輸入:show variables like ‘character_set_%’;
查看當前配置的編碼;
在MySQL命令行輸入 :set names utf8;
則等同於
set character_set_client=utf8;
set character_set_results=utf8;
set character_set_connection=utf8;
這三條命令
在命令行插入數據之前
執行命令set names gbk;或者set names gb2312;
再插入
查詢數據之前
執行命令set names gbk;或者set names gb2312;
完了之後再set names utf8;
這樣就能正常插入和查詢中文並且保持數據庫編碼爲utf8
對於mysqlworkbench中的查詢出現中文亂碼主要是由於mysql服務器的配置中默認設置的編碼不是utf8引起的,具體在windows操作系統下,要修改mysql安裝目錄下的my.ini
(linux下則是安裝目錄下的my.cnf文件)
主要修改的部分如下:
[client]
port=3306
[mysql]
default-character-set=utf8
[mysqld]
# The TCP/IP Port the MySQL Server will listen on
port=3306
#Path to installation directory. All paths are usually resolvedrelative to this.
basedir="D:/Program Files/MySQL/MySQL Server 5.1/"
#Path to the database root
datadir="D:/MySQL/MySQL Server 5.1/Data/"
# The default character set that will be used when a new schema ortable is
# created and no character set is defined
default-character-set=utf8
具體修改的部分就是紅色粗體字的文字部分。