文档章节

Mybatis中mysql blob类型乱码解决

Fraud
 Fraud
发布于 2016/05/06 11:03
字数 305
阅读 962
收藏 1

解决方法:

1,写一个 typehandler

package com.aes.util;

import java.io.ByteArrayInputStream;
import java.io.UnsupportedEncodingException;
import java.sql.Blob;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;

public class MyBlobTypeHandler extends BaseTypeHandler<String>
{
	//指定字符集  
    private static final String DEFAULT_CHARSET = "utf-8";  
  
    @Override  
    public void setNonNullParameter(PreparedStatement ps, int i,  
            String parameter, JdbcType jdbcType) throws SQLException {  
        ByteArrayInputStream bis;  
        try {  
            //把String转化成byte流  
            bis = new ByteArrayInputStream(parameter.getBytes(DEFAULT_CHARSET));  
        } catch (UnsupportedEncodingException e) {  
            throw new RuntimeException("Blob Encoding Error!");  
        }     
        ps.setBinaryStream(i, bis, parameter.length());  
    }  
  
    @Override  
    public String getNullableResult(ResultSet rs, String columnName)  
            throws SQLException {  
        Blob blob = rs.getBlob(columnName);  
        byte[] returnValue = null;  
        if (null != blob) {  
            returnValue = blob.getBytes(1, (int) blob.length());  
        }  
        try {  
            //把byte转化成string  
            return new String(returnValue, DEFAULT_CHARSET);  
        } catch (UnsupportedEncodingException e) {  
            throw new RuntimeException("Blob Encoding Error!");  
        }  
    }  
  
    @Override  
    public String getNullableResult(CallableStatement cs, int columnIndex)  
            throws SQLException {  
        Blob blob = cs.getBlob(columnIndex);  
        byte[] returnValue = null;  
        if (null != blob) {  
            returnValue = blob.getBytes(1, (int) blob.length());  
        }  
        try {  
            return new String(returnValue, DEFAULT_CHARSET);  
        } catch (UnsupportedEncodingException e) {  
            throw new RuntimeException("Blob Encoding Error!");  
        }  
    }

	@Override
	public String getNullableResult(ResultSet rs, int index) throws SQLException
	{
		Blob blob = rs.getBlob(index);  
        byte[] returnValue = null;  
        if (null != blob) {  
            returnValue = blob.getBytes(1, (int) blob.length());  
        }  
        try {  
            //把byte转化成string  
            return new String(returnValue, DEFAULT_CHARSET);  
        } catch (UnsupportedEncodingException e) {  
            throw new RuntimeException("Blob Encoding Error!");  
        }  
	}  
}


2,修改mybatis配置文件

<resultMap type="com.aes.wfm.model.ActHiComInfo" id="actHiComInfo">  
        <id column="id" property="id"/>
        <result column="userId" property="userId"/>
        <result column="startTime" property="startTime"/>
        <result column="endTime" property="endTime"/>
        <result column="taskName" property="taskName"/>
        <result column="message" property="message"/>
        <result column="fullMsg" property="fullMsg" typeHandler="com.aes.util.MyBlobTypeHandler"/>
</resultMap>


© 著作权归作者所有

共有 人打赏支持
Fraud
粉丝 39
博文 36
码字总数 25050
作品 0
程序员
私信 提问
springboot读写geometry字段,求解答

遇到了一个难题!!!数据库使用的是mysql,表里面有一个geometry字段 后台框架使用过的是Spring Boot集合Mybatis,实体类上对应的是byte[]类型,但是读取出来的数据就会乱码 目前的解决方案...

如漩涡
09/07
201
3
使用mysql group_concat函数的陷阱

开发中我的mysql 中使用了group_concat,然后导出的内容发现是乱码,如下图 运行了下sql语句,发现records字段和needs字段类型是blob二进制类型 BLOB (binary large object),二进制大对象,...

chenfj_fer
01/24
0
0
java通过mybatis往mysql数据库插入数据乱码

今天发现了一个问题,通过mybatis往数据库插入数据后,在数据库中所插入的中文乱码,开始以为是mysql编码设置问题,于是设置了mysql数据库的编码,但是不起作用,自己写的sql语句有中文插入也...

留给明天
2016/01/29
63
0
mysqldump 导出中文乱码

mysqldump 导出中文乱码 能检查的也都正常 1、通过navicat上做导出都是正常的 2、接着去检查数据库里编码,看也都是正常 show variables like 'char%'; +--------------------------+-------...

holy2009
2017/07/25
0
0
Mybatis问题点汇总

1、在mybatis链接mysql时候,出现中文乱码情况,排除了不是数据库的编码问题 jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf8 添加了useUnicode=true&characterEn...

吹比龙
2016/04/28
34
0

没有更多内容

加载失败,请刷新页面

加载更多

Qt那些事0.0.15

以下与Q_DECLARE_METATYPE相关内容全部是翻译自Qt文档。参看QVariant Class | Qt Core 5.9以及QMetaType Class | Qt Core 5.9 QVariant QVariant::fromValue(const T& value) 返回一份包含v......

Ev4n
11分钟前
1
0
spring上传文件返回绝对路径,简单工具类

import com.google.common.io.Files;import lombok.extern.slf4j.Slf4j;import org.springframework.web.multipart.MultipartFile;import java.io.File;import java.io.IOExceptio......

Boss-x
23分钟前
2
0
1个开发如何撑起一个过亿用户的小程序

本文由云+社区发表 2018年12月,腾讯相册累计用户量突破1亿,月活1200万,阿拉丁指数排行 Top 30,已经成为小程序生态的重量级玩家。 三个多月来,腾讯相册围绕【在微信分享相册照片】这一核...

腾讯云加社区
29分钟前
7
0
golang ssh包使用方法介绍

在使用gexpect包发现很多问题之外,这里又尝试使用ssh user@127.0.0.1的思路进行用户切换。这里记录下具体的使用方法,遇到的ssh: must specify HostKeyCallback 问题的解法方法及最终使用过...

linuxprobe16
34分钟前
2
0
layer

Layui Layer在open弹出层中异步加载数据和form表单radio、checkbox、select不渲染,不可点击的解决办法 layer 实现弹窗提交信息 function confirmUpdateAward(i) { layer.open({ ...

mickelfeng
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部