Mybatis实现自定义类型转换器TypeHandler的方法

作者:mrr 时间:2023-09-28 14:52:22 

先给大家简单介绍下mybatis

MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。

Mybatis实现自定义类型转换器TypeHandler的方法

此文其实是java操作Oracle类型XMLType总结二:使用Mybatis附带的一篇小结。

Mybatis实现自定义的转换器,十分的简单,其主要步骤分为三步,这里以操作XMLType类型为例。

第一步

新建一个转换类,实现TypeHandler接口,接口的泛型指定参数类型,不指定则为Object:


public class XmltypeTypeHandler implements TypeHandler<String>

该接口主要有以下4个方法:


public void setParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) public String getResult(ResultSet rs, String columnName) throws SQLException
public String getResult(ResultSet rs, int columnIndex) throws SQLException
public String getResult(CallableStatement cs, int columnIndex) throws SQLException

方法的作用看名字应该就能明白,setParameter是传入参数时的操作,在参数传入到数据库前需要做加工处理的代码,可以写在该方法内,其它三个均为获取查询结果方法,在得到jdbc的查询结果后可以转换为任意你想要的类型。

第二步

在mapper-config中,注册你实现的转换器类,其中jdbcType可以指定的类型在Mybatis的枚举类org.apache.ibatis.type.JdbcType中有明确的定义,不能为该枚举以外的值,不然会出错。这里因为枚举中没有我们需要的XMLType类型,所以指定为UNDEFINED。(也可以不指定具体的类型,在使用时用typeHandler指定具体的类即可):


<typeHandlers>
<typeHandler javaType="string" jdbcType="UNDEFINED" handler="com.tyyd.dw.context.XmltypeTypeHandler"/>
</typeHandlers>

第三步

在你的mapper映射文件中使用类型转换器:


insert into T_Content(
<include refid="fullColumns"/>
) values (
#{controlId,jdbcType=BIGINT},
#{xmlFile,javaType=string,jdbcType=UNDEFINED,typeHandler=com.tyyd.dw.context.XmltypeTypeHandler},
#{drmFile,jdbcType=BLOB}
)

注意传入的xmlFile参数,指定了javaType、jdbcType和typeHandler,表明我们要使用哪个类型处理器,当然你也可以只指定其中的某一项,但是该项存在必须唯一,如果一模一样存在多个又指定不清晰的话,Mybatis会因为不能进行区分而出现错误。

至此,一个mybatis的自定义类型转换器就实现完成了,需要注意的是,上面指定的类型处理器仅在插入数据时起作用,想要在查询时也使用自定义的类型处理器,需要在resultMap内属性的标签中进行指定,其指定的标签javaType、jdbcType和typeHandler名称和使用方式都是一样的,这里就不再赘述。

附上完整的类型转换器代码,因为XMLType类型要查询时,可以使用数据库的xmltype.getclobval()直接返回当成string来操作,所以返回的方法都没有进行特殊处理。(也可以使用xmltype.getstringval()函数返回string,但在实际使用过程中发现当字段为null时,getstringval()会出现ORA-06502:numeric or value error:character string buffer too small的错误,getclobval()则不会出现错误,所以推荐使用getclobval()函数):


/**
* oracle SYS.XMLTYPE 类型自定义处理器
*
* User: liyd
* Date: 13-12-27
* Time: 下午4:53
*/
public class XmltypeTypeHandler implements TypeHandler<String> {
@Override
public void setParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType)
throws SQLException {
//防止为null时,创建XMLType出现错误
if (StringUtils.isNotBlank(parameter)) {
DelegatingConnection connection = (DelegatingConnection) ps.getConnection()
.getMetaData().getConnection();
XMLType xmltype = XMLType.createXML(connection.getDelegate(), parameter);
ps.setObject(i, xmltype);
} else {
ps.setString(i, null);
}
}
@Override
public String getResult(ResultSet rs, String columnName) throws SQLException {
//数据库sql查询时xmltype字段使用xmltype.getclobval()返回
return rs.getString(columnName);
}
@Override
public String getResult(ResultSet rs, int columnIndex) throws SQLException {
return rs.getString(columnIndex);
}
@Override
public String getResult(CallableStatement cs, int columnIndex) throws SQLException {
return cs.getString(columnIndex);
}
}

以上所述是小编给大家介绍的Mybatis实现自定义类型转换器TypeHandler的方法网站的支持!

标签:mybatis,类型转换器,typehandler
0
投稿

猜你喜欢

  • 浅谈Service Manager成为Android进程间通信(IPC)机制Binder守护进程之路

    2021-09-04 05:48:21
  • 基于Elasticsearch5.4的常见问题总结

    2022-07-15 15:02:49
  • Java 单向队列及环形队列的实现原理

    2022-12-10 22:09:11
  • Java实现的计时器【秒表】功能示例

    2023-11-10 21:24:50
  • 实现Android键盘的中英文适配

    2022-03-27 20:40:33
  • spring security自定义登录页面

    2022-06-11 14:03:04
  • java Hibernate多对多映射详解及实例代码

    2023-07-02 07:24:40
  • Java执行SQL脚本文件到数据库详解

    2023-08-08 08:30:00
  • java高并发之理解进程和线程

    2023-09-16 20:03:17
  • java split()使用方法解析

    2023-10-18 01:59:23
  • Android GestureDetector实现手势滑动效果

    2023-10-01 04:37:50
  • Java中Collection、List、Set、Map之间的关系总结

    2022-11-18 21:41:42
  • Java 使用Socket正确读取数据姿势

    2023-09-16 12:13:43
  • Java Annotation注解相关原理代码总结

    2023-11-18 02:13:57
  • Java类加载基本过程详细介绍

    2023-04-15 10:54:14
  • c# chart缩放,局部放大问题

    2021-09-26 20:46:40
  • 详解Docker学习笔记之搭建一个JAVA Tomcat运行环境

    2022-09-03 02:26:06
  • C#四舍五入(函数)用法实例

    2022-02-03 21:51:16
  • java 请求跨域问题解决方法实例详解

    2023-08-24 02:55:11
  • Android组件之服务的详解

    2021-10-14 00:05:30
  • asp之家 软件编程 m.aspxhome.com