您现在的位置是:课程教程文章
mysql blob乱码
2023-12-18 18:09课程教程文章 人已围观
-
MYSQL5.1数据库从入门到精通/MYSQL数据库工
MYSQL5.1数据库从入门到精通/MYSQL数据库工本课程主要包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和... -
mysql数据库源码实战
mysql数据库源码实战mysql源码实战 源码下载 github.com/shuwenhe/shuwen-db 001.对SQL语句的分类 002.对SQL语句... -
如何搭建一款高性能、高可用的MySQL架构
如何搭建一款高性能、高可用的MySQL架构... -
JavaSE+数据库【编程入门精品课】/面向对
JavaSE+数据库【编程入门精品课】/面向对小伙伴们, 免费领取高清精品视频、笔记、源码 ,加小姐姐 QQ2709962849 还可加...
mysql中blob类型乱码的解决方法:
可以自己写个转换类,然后用自己的转换类进行转换。
转换类代码如下:
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"; 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 = (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!"); } } public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { Blob 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 columnIndex) throws SQLException { // TODO Auto-generated method stub return null; } }
在mybatis配置文件中指定
<result column="settlementContent" property="settlementContent" typeHandler="cn.xxx.utils.MyBlobTypeHandler"/>课程教程:mysql blob乱码
上一篇:mysql用c语言插入中文乱码
下一篇:没有了