1. TypeHandler简介

    TypeHandler,顾名思义类型转换器,就是将数据库中的类型与Java中的类型进行相互转换的处理器。

    MyBatis 在设置预处理语句(PreparedStatement)中的参数或从结果集中取出一个值时, 都会用类型处理器将获取到的值以合适的方式转换成 Java 类型

  2. 实现讲解

    经常自定义类型转换器方式有两种,实现 TypeHandler 接口, 或继承抽象类 BaseTypeHandle,并且可以指定转换后的字段类型。

    • 其实BaseTypeHandler也是继承了TypeHandler接口,在实现的TypeHandler接口的方法中调用的是自身抽象方法,如下
    public abstract class BaseTypeHandler<T> extends TypeReference<T> implements TypeHandler<T> {public T getResult(ResultSet rs, String columnName) throws SQLException {Object result;try {result = this.getNullableResult(rs, columnName);} catch (Exception var5) {throw new ResultMapException("Error attempting to get column '" + columnName + "' from result set.  Cause: " + var5, var5);}return rs.wasNull() ? null : result;}public abstract T getNullableResult(ResultSet var1, String var2) throws SQLException;
    }
    
    • 抽象类BaseTypeHandler的抽象方法
    // 执行之前,将Java类型转换为对应的jdbc类型,用于赋值sql中参数
    public abstract void setNonNullParameter(PreparedStatement var1, int var2, T var3, JdbcType var4) throws SQLException;// 根据列名从resultSet中获取,将JDBC类型转换为Java类型
    public abstract T getNullableResult(ResultSet var1, String var2) throws SQLException;// 根据下标从resultSet中获取,将JDBC类型转换为Java类型
    public abstract T getNullableResult(ResultSet var1, int var2) throws SQLException;// 用于在执行完存储过程后,将JDBC类型转换为Java类型
    public abstract T getNullableResult(CallableStatement var1, int var2) throws SQLException;
    
  3. 自定义类型处理器

    ​ 假设现在有一个支付标识(0-否 1-是)字段,数据库中我们存入的是tinyint 0/1,但是前端显示却是 是/否,使用TypeHandler就可以实现。具体步骤如下:

    • 新建MyTypeHandler,继承BaseTypeHandler类
    public class MyTypeHandler extends BaseTypeHandler<String> {/*** @Description 执行之前,将Java类型转换为对应的jdbc类型,用于赋值sql中参数**/@Overridepublic void setNonNullParameter(PreparedStatement preparedStatement, int i, String s, JdbcType jdbcType) throws SQLException {preparedStatement.setInt(i,Integer.valueOf(s));}/*** @Description 根据列名从resultSet中获取,将JDBC类型转换为Java类型**/@Overridepublic String getNullableResult(ResultSet resultSet, String s) throws SQLException {return this.convert(resultSet.getInt(s));}/*** @Description 根据下标从resultSet中获取,将JDBC类型转换为Java类型**/@Overridepublic String getNullableResult(ResultSet resultSet, int i) throws SQLException {return this.convert(resultSet.getInt(i));}/*** @Description 用于在执行完存储过程后,将JDBC类型转换为Java类型**/@Overridepublic String getNullableResult(CallableStatement callableStatement, int i) throws SQLException {return this.convert(callableStatement.getInt(i));}/*** @Description 对数据库中0/1进行转换**/private String convert(int flag){if (flag==1){return "是";}return "否";}
    }
    
    • 在Mapper中指定需要转换的字段,jdbcType指数据库中的类型,javaType指Java中的类型,typeHandler指定自定义的转换器
    <result column="flag" property="flag" jdbcType="TINYINT" javaType="java.lang.String" typeHandler="com.rangers.MyTypeHandler"></result>
    
    • 进行测试
        private SqlSession sqlSession ;private OrderMapper orderMapper;@Beforepublic void init() throws IOException {InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);sqlSession = sqlSessionFactory.openSession();orderMapper = sqlSession.getMapper(OrderMapper.class);}// 测试读取时转换@org.junit.Testpublic void testResult(){Order order = orderMapper.selectOne(1);System.out.println(order);}// 测试传入时转换@org.junit.Testpublic void testParameter(){// 假设前端传入字符串0/1List<Order> orders = orderMapper.selectOneByFlag("1");System.out.println(orders);}@Afterpublic void close(){sqlSession.close();}
    
    [Order{id=2, time=Wed Mar 10 17:22:45 CST 2021, total=2.22, uid=1, flag=是}, Order{id=3, time=Wed Mar 10 17:22:57 CST 2021, total=3.33, uid=2, flag=是}]
    
  4. 全局字段转换与单个字段转换

    全局转换:在核心配置文件中添加typeHandlers标签

    <typeHandlers><typeHandler handler="com.rangers.MyTypeHandle"/>
    </typeHandlers>
    

    单个字段转换:指定jdbcType、javaType与typeHandler

    <result column="flag" property="flag" jdbcType="TINYINT" javaType="java.lang.String" typeHandler="com.rangers.MyTypeHandler"></result>
    

    通常在项目中使用的是单个字段进行转换,经常自定义类型处理器还有日期处理、加密字段处理、List处理,JSON处理等

MyBatis(九):MyBatis类型处理器(TypeHandler)详解相关推荐

  1. MyBatis自定义类型处理器 TypeHandler

    在项目开发中经常会遇到一个问题: 当我们在javabean中自定义了枚举类型或者其它某个类型,但是在数据库中存储时往往需要转换成数据库对应的类型,并且在从数据库中取出来时也需要将数据库类型转换为jav ...

  2. mysql在xml中jdbctype,MyBatis中的JdbcType映射使用详解

    Java项目涉及到数据库交互,以往常用的是JDBC,现在则有Hibernate.Mybatis等这些持久化支持. 项目中用到了MyBatis,和JDBC最显著的区别,就是SQL语句配置化,通过xml文 ...

  3. 深入浅出Mybatis系列(四)---配置详解之typeAliases别名(mybatis源码篇)

    上篇文章<深入浅出Mybatis系列(三)---配置详解之properties与environments(mybatis源码篇)> 介绍了properties与environments, ...

  4. Mybatis mapper代理SqlMapConfig.xml配置详解

    SqlMapConfig.xml是mybatis的全局配置文件: 1.mapper映射配置 >配置mapper的另外一种方式: <mappers> <mapper resour ...

  5. mysql text类型 使用方法_MySQL使用TEXT/BLOB类型的知识点详解

    一.TEXT和BLOB的区别 TEXT和BLOB家族之间仅有的不同是BLOB类型存储的是二进制数据,没有排序规则或字符集,而TEXT类型有字符集或排序规则.说白了如果要储存中文则选择TEXT. 二.默 ...

  6. SpringMVC 处理器适配器详解

    SpringMVC 处理器适配器详解 1.介绍 2.非注解处理器适配器 3.注解处理器适配器 4.总结 1.介绍 处理器适配器 HandlerAdapter:作用是根据映射器找到的处理器 Handle ...

  7. 图像仿射变换原理3:仿射变换类型及变换矩阵详解

    ☞ ░ 老猿Python博文目录:https://blog.csdn.net/LaoYuanPython ░ 仿射变换博文传送门(带星号的为付费专栏文章): *图像仿射变换原理1:齐次坐标来龙去脉详解 ...

  8. Elasticsearch中字段类型(Field Type)详解

    ElasticSearch 7.7 字段类型(Field datatype)详解 字符串, object, 数值, 日期, 数组, 0x00 字符串: text, keyword 5.0以后,stri ...

  9. java enum类默认常量是什么_Java枚举类型enum的详解及使用

    Java枚举类型enum的详解及使用 最近跟同事讨论问题的时候,突然同事提到我们为什么Java 中定义的常量值不采用enmu 枚举类型,而采用public final static 类型来定义呢?以前 ...

最新文章

  1. win10应用开发——如何判断应用是在手机上运行还是电脑上运行
  2. 吴恩达的二八定律:80%的数据+20%的模型=更好的机器学习
  3. TortoiseSVN SendRpt.exe not found解决方案
  4. 数据结构-----栈
  5. android 6.0 logcat机制(三)logd处理请求log
  6. JavaFX键盘事件
  7. c# asp.net mvc 开发的正方教务助手(一)
  8. 章方:征服耶鲁教授的算法大神程序媛
  9. mysql(mariadb)的安装与使用,mysql相关命令,mysql数据类型
  10. 腾讯股价创新高:总裁刘炽平减持40万股 套现2.5亿港元
  11. Egret白鹭开发微信小游戏手机震动功能
  12. python中jupyter notebook 去掉警告
  13. Git入门(本地使用)
  14. 「安妮股份」拉上小米做版权联盟
  15. 免费又好用的Redis客户端工具!AnotherRedisDesktopManager
  16. 基于ArcScene简单实验操作
  17. BootStrap3 排版
  18. 安装RSF自动化环境
  19. 选择华为账号第三方登录,让你无法拒绝的3个理由
  20. Nim 游戏和 SG 函数

热门文章

  1. android studio识别不到夜神模拟器怎么办
  2. 侍魂胧月服务器维护,侍魂胧月传说什么时候开新区 新区开服时间表
  3. CF 868 div2 A—C
  4. 【MongoDB 快速上手】别找了,主流开源分布式系统存储系统三剑客:FastDFS、Minio、MongoDB零基础入门实战教程!
  5. js实现时间每秒更新
  6. Machine Learning Algorithms Study Notes
  7. Cantor三分集的递归算法
  8. 如何调教ChatGPT成为你的策略助手
  9. 基于keil5 的stm32F103C8T6的ST-LINK V2的仿真器使用
  10. 硕士毕业论文模板(专业硕士)