程序运行,向表中插入数据(包含中文)报错:\xe6\xb2\x88\xe9\x9b\xaa...
但是自己另外新建一个数据库手动插入数据中文正常,同样修改数据库,表的编码之后同样不行。而且 mysql5.7下也会出现这种情况无法解决。
在 hibernate 主配置文件中,我们会配置数据库方言,一般配置如下:
<property name="hibernate.dialect">org.hibernate.dialect.mysqldialect</property>
查看其对应源码可以查看到有个方法,如下:
@override public string gettabletypestring() { return "engine=innodb"; }
所以我们可以自定义一个类,重写上面方法,如下:
package com.taohan.util; import org.hibernate.dialect.mysql5innodbdialect; public class hibernateencodeadapter mysql5innodbdialect { @override public string gettabletypestring() { return "engine=innodb default charset=utf8"; } }
最后修改 hibernate 主配置文件,指定数据库方言类为我们自定义的那个,如下:
<property name="dialect">com.taoahn.util.hibernateencodeadapter</property>
当然,最好是同时在 hibernate 主配置文件的设置数据库连接路径后加上 ?useunicode=true&characterencoding=utf-8,如下:
<property name="hibernate.connection.url">jdbc:mysql:///test?useunicode=true&characterencoding=utf-8</property>
参考地址:https://blog.csdn.net/fukua2017/article/details/78878443
如对本文有疑问, 点击进行留言回复!!
Android 4.0使用Kotlin调用C语言以及汇编语言
Java Class.forName()用法和newInstance()方法原理解析
网友评论