当前位置: 移动技术网 > IT编程>开发语言>Java > 记一次 Hibernate 插入数据中文乱码报错解决

记一次 Hibernate 插入数据中文乱码报错解决

2018年10月11日  | 移动技术网IT编程  | 我要评论

错误描述

程序运行,向表中插入数据(包含中文)报错:\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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网