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

Posted dream-saddle

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记一次 Hibernate 插入数据中文乱码报错解决相关的知识,希望对你有一定的参考价值。

错误描述

程序运行,向表中插入数据(包含中文)报错:xE6xB2x88xE9x9BxAA...

但是自己另外新建一个数据库手动插入数据中文正常,同样修改数据库,表的编码之后同样不行。而且 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

以上是关于记一次 Hibernate 插入数据中文乱码报错解决的主要内容,如果未能解决你的问题,请参考以下文章

[软件测试_hw1]记一次调试bug的经历

记一次中文乱码解决过程

记一次InputStream引起的乱码

记一次IntelliJ IDEA中文乱码问题

记一次Maven发布Jar包中文乱码解决方法

记一次MySQL注入绕过