Hibrenate 连接 MySQL保存数据时候的乱码问题

网上很多方法,实验了,很少有成功的,弄了好久,总结如下:

MySQL的字符集支持(Character Set Support)有两个方面:字符集(Character set)和排序方式(Collation)。对于字符集的支持细化到四个层次: 

服务器(server),数据库(database),数据表(table)和连接(connection)。

可以用:show variables like 'character%';查看字符编码

            mysql> SHOW VARIABLES LIKE 'collation_%'; 查看系统排序方式的设定

mysql乱码处理总结:
      (1)java中处理中文字符正常,在cmd client中显示乱码是字符集的问题.
       (2)字段长度设置够长,但插入中文字符时提示com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column错误是字符集的问题.
       (3)乱码问题归根到底是字符集的问题,那就从字符集设置方面考虑,不外乎下面几个方面:server,client,database,connection,results.

-------------------------解决办法----------------------
(1)修改 my.ini(MySQL Server Instance Configuration 文件)
# CLIENT SECTION //客户端
[client]
port=3306
[mysql]
default-character-set=gbk
# SERVER SECTION   //服务端
[mysqld]
default-character-set=gbk
(2)修改data目录中相应数据库目录下的db.opt配置文件
default-character-set=gbk
default-collation=gbk_chinese_ci
(3)数据库连接串中指定字符集
URL=jdbc:mysql://yourIP/college?user=root&password=yourPassword&useUnicode=true&characterEncoding=gbk 注:在mysql4.1.0版要加useUnicode=true&characterEncoding=gbk 如果是5.0版以上的,加不加都是没有关系的!
(4)在创建数据库时指定字符集
create database yourDB CHARACTER SET gbk;

(5)在dos命令上要设置

set names gbk
com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column等问题.

按照上面的方法,将MySQL 数据库的sever , client , Connect 等的编码设置成 gbk 可是用 Hibernate 向数据库中插入依旧不能保持为中文,必须在 Hibernate.cfg.xml 文件中 加一条语句

<property name="connection.characterEncoding">gbk</property>
至于深层次的东西,依旧不懂,还待进一一步研究,菜鸟先飞。





你可能感兴趣的:(mysql,数据库,database,character,collation,variables)