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. mvel

    https://en.wikipedia.org/wiki/MVEL import java.util.*; // the main quicksort algorithm def quicksort ...

  2. simplest_ffmpeg_grabdesktop:屏幕录制。 simplest_ffmpeg_readcamera:读取摄像头

    最简单的基于FFmpeg的AVDevice例子(屏幕录制) - 雷霄骅(leixiaohua1020)的专栏 - CSDN博客 https://blog.csdn.net/leixiaohua1020 ...

  3. Map,Filter和Reduce

    转自:https://www.aliyun.com/jiaocheng/444967.html?spm=5176.100033.1.13.xms8KG 摘要:Map,Filter和Reduce三个函数 ...

  4. 原!!关于java 单元测试Junit4和Mock的一些总结

    最近项目有在写java代码的单元测试,然后在思考一个问题,为什么要写单元测试??单元测试写了有什么用??百度了一圈,如下: 软件质量最简单.最有效的保证: 是目标代码最清晰.最有效的文档: 可以优化目 ...

  5. java 字符串解析为json 使用org.json包的JSONObject+JSONArray

    参考: https://blog.csdn.net/xingfei_work/article/details/76572550 java中四种json解析方式 JSONObject+JSONArray ...

  6. Linux入门之运维(1) 系统监控 vmstat top

    vmstat命令是最常见的Linux/Unix监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,内存使用,虚拟内存交换情况,IO读写情况.这个命令是我查看Linux/Unix最 ...

  7. 【我的Android进阶之旅】Android使用getIdentifier()方法根据资源名来获取资源id

    有时候我们想动态的根据一个资源名获得到对应的资源id,就可以使用getResources().getIdentifier()方法来获取该id.然后再使用该id进行相关的操作. 1.Demo示例 下面用 ...

  8. Linux(1)- 服务器核心知识、Linux入门、VMware与centeos安装、远程连接linux、linux基本命令使用

    一.服务器核心知识 1.电脑和电脑的硬件组成 现在的人们几乎无时无刻不在使用着电脑!不管是桌上型电脑(桌机).笔记型电脑(笔电).平板电脑,还是智慧型手机等等,这些东西都算是电脑.虽然接触这么多,但是 ...

  9. 吴超老师课程---Hadoop的伪分布安装

    1.1 设置ip地址    执行命令    service network restart    验证:         ifconfig1.2 关闭防火墙    执行命令    service ip ...

  10. BOM对象,math对象document对象的属性和操作和 事件的基本操作

    Math对象 //该对象中的属性方法 和数学有关. abs(x) 返回数的绝对值. exp(x) 返回 e 的指数. floor(x) 对数进行下舍入. log(x) 返回数的自然对数(底为e). m ...