mysql编码详解
在开发程序的时候,我们使用mysql数据库开发的时候,有时会碰到自己明明输入的是中文,为什么数据库中存储的就是????
1、在配置Connection URL时,加上?useUnicode=true&characterEncoding=utf-8
2、编辑/etc/my.cnf
在[mysqld]下添加
default-character-set=utf8
在[client]下添加
default-character-set=utf8
可是这样做的原理是什么?为什么这样做就能解决问题那?
逐步分析一下:
1、useUnicode=true这个用加吗?答案是不用,翻看connector-j-en.a4.pdf
它的默认值就是true
2、 mysqld 下的default_character_set=utf8;,这个需要吗?答案是不需要。查看refman-5.1
它的作用是
当启动mysqld时,根据使用的初始选项设置来确定服务器字符集和 校对规则。可以使用--default-character-set设置字符集;
如果在CREATE TABLE语句中没有指定表字符集和校对规则,则使用数据库字符集和校对规则作为默认值。默认数据库的字符集和校对规则可以用作character_set_database和 collation_database系统变量。无论何时默认数据库更改了,服务器都设置这两个变量的值。如果没有 默认数据库,这两个变量与相应的服务器级别的变量(character_set_server和collation_server)具有相同的值。
大白话就是:如果你建表的时候没有指定字符编码,则会使用character_set_database,如果character_set_database也没有设值,则使用character_set_server
3、 client 下的default_character_set=utf8; 它是需要的,可是它的作用是干吗的?
它的作用等同执行以下3个命令
SET character_set_client = utf8
SET character_set_results = utf8;
SET character_set_connection = utf8;
这3个参数的作用如下
系统变量character_set_client:用来指定解析客户端传递数据的编码
系统变量character_set_connection:用来指定数据库内部处理时使用的编码
系统变量character_set_results:用来指定数据返回给客户端的编码方式
现在讲述一下?useUnicode=true&characterEncoding=utf-8中的characterEncoding
它的作用就是指定character_set_client和character_set_connection的值,而在jdbc链接中使用characterSetResults=UTF-8,即可设置character_set_results的值
但是如上所述,当你配置了client的default_character_set之后,characterEncoding和characterSetResults这两个变量你设置与否都不重要了。
结论如下:
如果你只愿意配置服务器的话:
在[client]下添加
default-character-set=utf8即可
如果你只愿意配置客户端的话:
你可以使用jdbc:mysql://localhost:3306/test? characterEncoding=UTF-8&characterSetResults=UTF-8即可
使用jdbc
character_set_client - utf8
character_set_connection - utf8
character_set_database - utf8
character_set_filesystem - binary
character_set_results -
character_set_server - utf8
character_set_system - utf8
character_sets_dir - /usr/share/mysql/charsets/
使用mysql客户端
character_set_client utf8 | ||
character_set_connection utf8 | ||
character_set_database utf8 | ||
character_set_filesystem binary | ||
character_set_results utf8 | ||
character_set_server utf8 | ||
character_set_system utf8 | ||
character_sets_dir /usr/share/mysql/charsets/ |