MYSQL数据库默认语言为瑞典语,现有一GB2312字符的数据库.
结构OK.为什么内容是乱码?不重装数据库有办法解决码?
从MySQL4.1开始引入的多语言支持确实很棒,而且一些特性已经超过了其他的数据库系统。不过我在测试过程中发现使用适用于MySQL4.1之前的PHP语句操作MySQL数据库会造成乱码,即使是设置过了表字符集也是如此。我读了一下新的MySQL在线手册中第十章"CharacterSetSupport"后终于找到了解决方法并测试通过。
MySQL4.1的字符集支持(CharacterSetSupport)有两个方面:字符集(Characterset)和排序方式(Collation)。对于字符集的支持细化到四个层次:服务器(server),数据库(database),数据表(table)和连接(connection)。
查看系统的字符集和排序方式的设定可以通过下面的两条命令:
mysql>SHOWVARIABLESLIKE'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/|
+--------------------------+----------------------------+
7rowsinset(0.00sec)
mysql>SHOWVARIABLESLIKE'collation_%';
+----------------------+-------------------+
|Variable_name|Value|
+----------------------+-------------------+
|collation_connection|latin1_swedish_ci|
|collation_database|latin1_swedish_ci|
|collation_server|latin1_swedish_ci|
+----------------------+-------------------+
3rowsinset(0.00sec)
上面列出的值就是系统的默认值。(很奇怪系统怎么默认是latin1的瑞典语排序方式)...
当我们按照原来的方式通过PHP存取MySQL数据库时,就算设置了表的默认字符集为utf8并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在这个connection连接层上。解决方法是在发送查询前执行一下下面这句:
SETNAMES'GBK';
它相当于下面的三句指令:
SETcharacter_set_client=GBK;
SETcharacter_set_results=GBK;
SETcharacter_set_connection=GBK;
一定要执行了上面的语句(SETNAMES'GBK';)之后再建立数据库。
JSP文件第一行必须是:<%@pagelanguage="java"contentType="text/html;charset=GBK"pageEncoding="GBK"%>
连接MySQL时的url必须有:url="jdbc:mysql://localhost/bbs?user=root&password=tpfpcwl&useUnicode=true&characterEncoding=utf-8";
<!--EndFragment-->