MySQL 4.1的字符集支持(Character Set Support)有两个方面:字符集(Character set)和排序方式(Collation)。对于字符集的支持细化到四个层次: 服务器(server),数据库(database),数据表(table)和连接(connection)。我们最终的目标是使得这四个层次转化会支持中文的编码,下面以utf8为例。

1. 首先查看系统的字符集和排序方式。如果想查看某个特定的数据库的字符集和排序方式,应该先选定数据库,mysql>use databasename; 
mysql> SHOW VARIABLES LIKE ''character_set_%''; 
+--------------------------+----------------------------+ 
| Variable_name | Value | 
+--------------------------+----------------------------+ 
| character_set_client | latin1 | 
| character_set_connection | latin1 | 
| character_set_database | latin1 | 
| character_set_results | latin1 | 
| character_set_server | latin1 | 
| character_set_system | utf8 | 
| character_sets_dir | /usr/share/mysql/charsets/ | 
+--------------------------+----------------------------+ 
7 rows in set (0.00 sec) 
mysql> SHOW VARIABLES LIKE ''collation_%''; 
+----------------------+-------------------+ 
| Variable_name | Value | 
+----------------------+-------------------+ 
| collation_connection | latin1_swedish_ci | 
| collation_database | latin1_swedish_ci | 
| collation_server | latin1_swedish_ci | 
+----------------------+-------------------+ 
3 rows in set (0.00 sec) 
上面列出的值就是系统的默认值,lanti是不支持中文的,所以我们把它改成urf8。

下面我们就来修改这四个层次的编码方式: 
1 在my.cf文件的[mysqld]段设置: 
default-character-set=utf8 
这条语句的作用是把character_set_client, character_set_connection_,character_set_results 设定为utf8,包括对应的排列方式的编码。 
Character_set_server是系统编码,这个是不用改的。 

当然改变character_set_client, character_set_connection_,character_set_results编码方式的另外一种方法是:SET NAMES “UTF8”; 
它的作用相当于: 
SET character_set_client = utf8; 
SET character_set_results = utf8; 
SET character_set_connection = utf8;

2 然后就是要改变数据库链接方式

url路径后要加上 ?useUnicode=true&characterEncoding=utf-8,如果是在spring配置中设置,&要替换为&

3 jsp页面上要加上使支持UTF-8

<%@ page language="java" import="java.util.*" contentType="text/html; charset=UTF-8" %>