Mybatis_review之配置文件中的typeHandlers节点内容说明

Mybatis为什么要在configuration file中提供typeHandlers节点

因为java类型与数据库中保存的类型是有很大差异的,例如 在java中的类型为int,但是在数据库中可能为int也可能为number。因此建立数据库的类型映射是非常重要的。为了兼容多个数据库,以及考虑到未来数据库的发展,Mybatis采用了插入的方式来解决类型映射的问题。

我们可以在mybatis的文件夹org.apache.ibatis.type的下面看到很多中typeHandler。与其他的框架中的实现方式一样,他们都有两种实现方式,第一种就是实现某一个接口,另外一个是继承某一个抽象类。

在Mybatis的官方文档中,也提到了typeHandler节点,这个节点位于配置文件中,可以用来指定Mybatis在插入某类型参数以及从结果集中取出该类型的参数的默认动作,我们可以用这个特性来做很多事情,例如,我们在数据库中存储了男 =0 女=0 性别未知=9,但是在查询的时候,需要将上面的码值转码,现有的系统情况不允许我们修改前台逻辑与SQL逻辑,这个时候,了解Mybatis的该特性确实还是能够帮助我们一个大忙的,尽管这个时候,未必是最好的解决方案。

如何扩展Mybatis的typeHandler

扩展Mybatis的typeHandler是非常简单的,可以实现特定接口,也可以继承特定的抽象类,然后实现他们的抽象方法。实现接口的代码如下:

<span style="font-family:KaiTi_GB2312;">package com.samsung.mybatis;

import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.TypeHandler;

public class ZwIntegerTypeHandler implements TypeHandler<Integer>{

    @Override
    public void setParameter(PreparedStatement ps, int i, Integer parameter,
            JdbcType jdbcType) throws SQLException {
        ps.setInt(i, parameter);
    }

    @Override
    public Integer getResult(ResultSet rs, String columnName)
            throws SQLException {
        return Integer.valueOf(rs.getString(columnName));
    }

    @Override
    public Integer getResult(ResultSet rs, int columnIndex) throws SQLException {
        return Integer.valueOf(rs.getString(columnIndex));
    }

    @Override
    public Integer getResult(CallableStatement cs, int columnIndex)
            throws SQLException {
        return Integer.valueOf(cs.getString(columnIndex));
    }

}
</span>

然后在配置文件中,添加一个节点。这里面也支持两种方式,第一种是注解来扫描的方式,另外一种,则是通过指定类的方式。使用第二种方式的代码如下:

<span style="font-family:KaiTi_GB2312;"><typeHandlers>
   <typeHandler handler="com.samsung.mybatis.ZwIntegerTypeHandler" javaType="Integer"/>
</typeHandlers>
</span>

Mybatis_review之配置文件中的typeHandlers节点内容说明

时间: 2024-11-03 21:15:32

Mybatis_review之配置文件中的typeHandlers节点内容说明的相关文章

Mybatis_review之配置文件中的properties节点内容说明

Properties的设置格式 在Demo项目中使用的Mybatis-config.xml文件中的配置如下: <span style="font-family:KaiTi_GB2312;"><?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN&quo

Mybatis_review之配置文件中的typeAliases节点内容说明

Mybatis为什么要提供别名? Mybatis最基础的Demo中体现要做的事情是非常简单的,如果使用原生的JDBC来实现数据库表与对象之间的映射的话,我们应该怎么做呢?首先,使用ClassForName在静态代码块中注册一个驱动类.然后,使用静态类DriverManager来获取一个数据库的连接对象,当然在这一步我们需要提供URL,username以及password等用于连接数据库以及鉴权的信息.第三,得到连接之后,建立statement或者是preparedStatment对象,第四,执行

Mybatis_review之配置文件中的objectFactory节点内容说明

Mybatis中有一个默认的创建类的对象,名字叫做DefaultObjectFactory,这个类用于负责创建对象实体类.从这个类的外部看,这个类的主要作用就是根据一个类的类型得到该类的一个实体对象,比如,我们给他一个Tiger的type,他将会给我们一个Tiger的实体对象,我们给他一个java.lang.List对象,他将会给我们一个List的实体对象.这个其实从它的名字上就能看出来. 这个类在官方文档中介绍到DefaultObjectFactory这个类的对象做的事情是非常少的,仅仅是创建

Spring配置文件中突然出现异常Referenced file contains errors

Referenced file contains errors (http://cxf.apache.org/schemas/jaxws.xsd). For more information, right click on the message in the Problems View and select "Show Details..." 在Eclipse IDE中的一个J2EE工程,之前是好好的,一段时间没去搭理. 有一天需要在项目中加点东西,打开工程一看,其中一个Spring

ASP.NET配置文件中常用到的节点信息

 web.config文件是一个XML文件,是以<confirguration>为根结点展开的.上一面从宏观上讲解了一下有关配置的文件的内容,下面是一些有关于配置文件常用的操作.图片请详见下图 .config常用操作 <appSettings>节点 主要用来存储asp.net应用程序的一些配置信息,个人感觉是存储一些以后可能会变化的配置信息.例如网页中上传文件的保存路径.个人曾做过有关XML一个小型的数据库,通过<appSettings>来反射XML文件的保存路径

drupal中根据不同的内容类型节点显示不同的样式

在template.tpl中添加如下代码: function lee_preprocess_node(&$variables) { if ($variables['view_mode'] == 'full' && node_is_page($variables['node'])) { $variables['classes_array'][] = 'node-full'; } } 在template文件下建立模板文件node--article.tpl.php 最后清除下缓存即可!

MySQL中双NDBD节点Cluster快速配置

是MySQL适合于分布式计算环境的高实用.高冗余版本.它采用了NDB Cluster 存储引擎,允许在1个 Cluster 中运行多个MySQL服务器.在MyQL 5.0及以上的二进制版本中.以及与最新的Linux版本兼容的RPM中提供了该存储引擎.(注意,要想获得MySQL Cluster 的功能,必须安装 mysql-server 和 mysql-max RPM).目前能够运行MySQL Cluster 的操作系统有Linux.Mac OS X和Solaris(一些用户通报成功地在FreeB

五种方式让你在java中读取properties文件内容不再是难题

一.背景 最近,在项目开发的过程中,遇到需要在properties文件中定义一些自定义的变量,以供java程序动态的读取,修改变量,不再需要修改代码的问题.就借此机会把Spring+SpringMVC+Mybatis整合开发的项目中通过java程序读取properties文件内容的方式进行了梳理和分析,先和大家共享. 二.项目环境介绍 Spring 4.2.6.RELEASE SpringMvc 4.2.6.RELEASE Mybatis 3.2.8 Maven 3.3.9 Jdk 1.7 Id

mybatis学习(三)----优化Mybatis配置文件中的配置

一.把连接数据库的配置单独放在一个properties文件中 前面我们是把数据库的连接信息放在了mybatis-config.xml中,如下: 1 <?xml version="1.0" encoding="utf-8" ?> 2 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/myb