Mysql中文亂碼問題完美解決方案


原文:http://www.2cto.com/database/201108/101151.html

MySQL會出現中文亂碼的原因不外乎下列幾點:
1.server本身設定問題,例如還停留在latin1
2.table的語系設定問題(包含character與collation)
3.客戶端程式(例如php)的連線語系設定問題
強烈建議使用utf8!!!!
utf8可以兼容世界上所有字符!!!!
一、避免創建數據庫及表出現中文亂碼和查看編碼方法
1、創建數據庫的時候:

[sql]  view plain  copy
 
  1. CREATE DATABASE `test`  
  2. CHARACTER SET 'utf8'  
  3. COLLATE 'utf8_general_ci';  

2、建表的時候 

[sql]  view plain  copy
 
  1. CREATE TABLE `database_user` (  
  2. `ID` varchar(40) NOT NULL default '',  
  3. `UserID` varchar(40) NOT NULL default '',  
  4. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

 

 

這3個設置好了,基本就不會出問題了,即建庫和建表時都使用相同的編碼格式。
但是如果你已經建了庫和表可以通過以下方式進行查詢。
1.查看默認的編碼格式:

[sql]  view plain  copy
 
  1. mysql> show variables like "%char%";  
  2. +--------------------------+---------------+  
  3. | Variable_name | Value |  
  4. +--------------------------+---------------+  
  5. | character_set_client | gbk |  
  6. | character_set_connection | gbk |  
  7. | character_set_database | utf8 |  
  8. | character_set_filesystem | binary |  
  9. | character_set_results | gbk |  
  10. | character_set_server | utf8 |  
  11. | character_set_system | utf8 |  
  12. +--------------------------+-------------+  


注:以前2個來確定,可以使用set names utf8,set names gbk設置默認的編碼格式;

 

執行SET NAMES utf8的效果等同於同時設定如下:

[sql]  view plain  copy
 
  1. SET character_set_client='utf8';  
  2. SET character_set_connection='utf8';  
  3. SET character_set_results='utf8';  

 

 

2.查看test數據庫的編碼格式:

[sql]  view plain  copy
 
  1. mysql> show create database test;  
  2. +------------+------------------------------------------------------------------------------------------------+  
  3. Database | Create Database |  
  4. +------------+------------------------------------------------------------------------------------------------+  
  5. | test | CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET gbk */ |  
  6. +------------+------------------------------------------------------------------------------------------------+  


3.查看yjdb數據表的編碼格式:

 

 

[sql]  view plain  copy
 
  1. mysql> show create table yjdb;  
  2. | yjdb | CREATE TABLE `yjdb` (  
  3. `sn` int(5) NOT NULL AUTO_INCREMENT,  
  4. `type` varchar(10) NOT NULL,  
  5. `brc` varchar(6) NOT NULL,  
  6. `teller` int(6) NOT NULL,  
  7. `telname` varchar(10) NOT NULL,  
  8. `date` int(10) NOT NULL,  
  9. `count` int(6) NOT NULL,  
  10. `back` int(10) NOT NULL,  
  11. PRIMARY KEY (`sn`),  
  12. UNIQUE KEY `sn` (`sn`),  
  13. UNIQUE KEY `sn_2` (`sn`)  
  14. ) ENGINE=MyISAM AUTO_INCREMENT=1826 DEFAULT CHARSET=gbk ROW_FORMAT=DYNAMIC |  
 

Select查詢表時中文顯示亂碼,運行命令 set character_set_results=gbk 后顯示為中文

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM