MyBatis虽然有很好的SQL执行性能,但毕竟不是完整的ORM框架,不同的数据库之间SQL执行还是有差异。

  笔者最近在升级 Oracle 驱动至 ojdbc 7 ,就发现了处理DATE类型存在问题。还好MyBatis提供了使用自定义TypeHandler转换类型的功能。

  本文介绍如下使用 TypeHandler 实现日期类型的转换。

  问题背景

  项目中有如下的字段,是采用的DATE类型:

  birthday = #{birthday, jdbcType=DATE},

  在更新 Oracle 驱动之前,DateOnlyTypeHandler会做出处理,将 jdbcType 是 DATE 的数据转为短日期格式(‘年月日’)插入数据库。毕竟是生日嘛,只需要精确到年月日即可。

  但是,升级 Oracle 驱动至 ojdbc 7 ,就发现了处理DATE类型存在问题。插入的数据格式变成了长日期格式(‘年月日时分秒’),显然不符合需求了。

  解决方案:

  MyBatis提供了使用自定义TypeHandler转换类型的功能。可以自己写个TypeHandler来对 DATE 类型做特殊处理:

  /**

  * Welcome to https://waylau.com

  */

  package com.waylau.lite.mall.type;

  import java.sql.CallableStatement;

  import java.sql.PreparedStatement;

  import java.sql.ResultSet;

  import java.sql.SQLException;

  import java.text.DateFormat;

  import java.util.Date;

  import org.apache.ibatis.type.BaseTypeHandler;

  import org.apache.ibatis.type.JdbcType;

  import org.apache.ibatis.type.MappedJdbcTypes;

  import org.apache.ibatis.type.MappedTypes;

  /**

  * 自定义TypeHandler,用于将日期转为'yyyy-MM-dd'

  *

  * @since 1.0.0 2018年10月10日

  * @author Way Lau

  */

  @MappedJdbcTypes(JdbcType.DATE)

  @MappedTypes(Date.class)

  public class DateShortTypeHandler extends BaseTypeHandler{

  @Override

  public void setNonNullParameter(PreparedStatement ps, int i, Date parameter, JdbcType jdbcType)

  throws SQLException {

  DateFormat df = DateFormat.getDateInstance();

  String dateStr = df.format(parameter);

  ps.setDate(i, java.sql.Date.valueOf(dateStr));

  }

  @Override

  public Date getNullableResult(ResultSet rs, String columnName) throws SQLException {

  java.sql.Date sqlDate = rs.getDate(columnName);

  if (sqlDate != null) {

  return new Date(sqlDate.getTime());

  }

  return null;

  }

  @Override

  public Date getNullableResult(ResultSet rs, int columnIndex) throws SQLException {

  java.sql.Date sqlDate = rs.getDate(columnIndex);

  if (sqlDate != null) {

  return new Date(sqlDate.getTime());

  }

  return null;

  }

  @Override

  public Date getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {

  java.sql.Date sqlDate = cs.getDate(columnIndex);

  if (sqlDate != null) {

  return new Date(sqlDate.getTime());

  }

  return null;

  }

  }

  如果是 Spring 项目,以下面方式进行 TypeHandler 的配置:

  !-- 自定义 --

  !--声明TypeHandler bean--

  bean id=dateShortTypeHandler class="com".waylau.lite.mall.type.DateShortTypeHandler/

  !-- MyBatis 工厂 --

  bean id=sqlSessionFactory class="org".mybatis.spring.SqlSessionFactoryBean

  property name=dataSource ref=dataSource /

  !--TypeHandler注入--

  property name=typeHandlers ref=dateShortTypeHandler/

  /bean

  如何使用 TypeHandler

  方式1 :指定 jdbcType 为 DATE

  比如,目前,项目中有如下的字段,是采用的DATE类型:

  birthday = #{birthday, jdbcType=DATE},

  方式2 :指定 typeHandler

  指定 typeHandler 为我们自定义的 TypeHandler:

  birthday = #{birthday, typeHandler=com.waylau.lite.mall.type.DateShortT

MyBatis使用自定义TypeHandler转换类型的更多相关文章

  1. MyBatis使用自定义TypeHandler转换类型的实现方法

    From: http://www.manongjc.com/article/15577.html 这篇文章主要介绍了MyBatis使用自定义TypeHandler转换类型的实现方法,本文介绍使用Typ ...

  2. mybatis实现自定义typeHandler

    java8以前的日期处理有多恶心,相信不少人都深有体会.与mabatis集成查询数据库中的日期字段映射为java日期类型或者字符型的时候,会多出一个".0".当然可以自行处理.但是 ...

  3. mybatis类型转换器 - 自定义全局转换enum

    在数据模型.接口参数等场景部分属性参数为一些常量值,比如性别:男.女.若是定义成int或String类型,于是类型本身的范围太宽,要求使用者需要了解底层的业务方可知如何传值,那整体来看增加沟通成本,对 ...

  4. Mybatis实战之自定义TypeHandler处理枚举

    在Mybatis中,处理枚举类的TypeHandler有两个: EnumTypeHandler: 用于保存枚举名 EnumOrdinalTypeHandler: 用于保存枚举的序号. 在实际项目中,以 ...

  5. mybatis自定义枚举转换类

    转载自:http://my.oschina.net/SEyanlei/blog/188919 mybatis提供了EnumTypeHandler和EnumOrdinalTypeHandler完成枚举类 ...

  6. mybatis 3的TypeHandler解析(null值的处理)

    最近,在测试迁移公司的交易客户端连接到自主研发的中间件时,调用DAO层时,发现有些参数并没有传递,而在mapper里面是通过parameterMap传递的,因为有些参数为null,这就导致了参数传递到 ...

  7. 解决mybatis使用枚举的转换

    解决mybatis使用枚举的转换 >>>>>>>>>>>>>>>>>>>>> ...

  8. mybatis入门系列三之类型转换器

    mybatis入门系列三之类型转换器 类型转换器介绍 mybatis作为一个ORM框架,要求java中的对象与数据库中的表记录应该对应 因此java类名-数据库表名,java类属性名-数据库表字段名, ...

  9. 两个案例轻松理解MyBatis中的TypeHandler!

    在做开发时,我们经常会遇到这样一些问题,比如我有一个Java中的Date数据类型,我想将之存到数据库的时候存成一个1970年至今的毫秒数,怎么实现?再比如我有一个User类,User类中有一个属性叫做 ...

随机推荐

  1. 学习使用turtlebot2——调试Hokuyo激光雷达(型号UST-10LX)

    目标 在ROS上调试使用Hokuyo激光雷达传感器 配置情况     电脑使用Ubuntu 14.04版本,ROS为 Indigo,激光雷达为Hokuyo(型号UST-10LX,网口型接口)   如果 ...

  2. Blog上一页和下一页的功能

    博客上一页和下一页的功能 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...

  3. 解决Windows 7 IIS7.5 用户 'IIS APPPOOL\{站点名} AppPool'登录失败

    今天调试程序的时候,使用VS调试没有任何问题,但是发布到IIS就发生错误了,网上搜索了一下,问题具体上就出在IIS的应用程序池的设置上.我使用的是Windows7 IIS7.5. 错误为:用户 'II ...

  4. Struts2 框架的值栈

    1. OGNL 表达式 1.1 概述 OGNL(Object Graphic Navigation Language),即对象图导航语言; 所谓对象图,即以任意一个对象为根,通过OGNL可以访问与这个 ...

  5. JQuery基础与事件和动画

    JQuery语法 1.JQuery("选择器").action; 通过选择器调用时间函数 但Jquery可以用$符号代替,即$("选择器").action; ① ...

  6. FastReports_4.14.1 _Cliff手动安装

    首次编译frx15.dproj包的时候,会出错: [DCC Fatal Error] fs15.dpk(59): F1026 File not found: 'fs_ipascal.dcu'原因是因为 ...

  7. Date、Calendar、Timestamp的区别与转换

    1.Java.util.Date 包含年.月.日.时.分.秒信息. // String转换为Date String dateStr="2013-8-13 23:23:23"; St ...

  8. 初识idea

    http://blog.csdn.net/bitcarmanlee/article/details/54951589 http://blog.csdn.net/haishu_zheng/article ...

  9. J2EE之JPA

    POJO(plain old java object普通java类):具有setter/getter方法的Java类就称为POJO POJO转化为实体,手工使用标记, @Entity public c ...

  10. 访问hdfs里的文件

    准备工作: 给hdfs里上传一份用于测试的文件 [root@master ~]# cat hello.txt hello 1 hello 2 hello 3 hello 4 [root@master ...