修改 mybatis-generator 中数据库类型和 Java 类型的映射关系

createh52个月前 (02-20)技术教程27

使用 mybatis-generator 发现数据库类型是 tinyint(4) , 生成 model 时字段类型是 Byte ,使用的时候有点不便

数据库的类型和 Model 中 Java 类型的关系是由 JavaTypeResolver 控制的, 查资料发现可以在生成配置中指定表中的某一个字段的 JavaType, 但不能全局配置.

如果想改某一个表的话某个字段, 只需要在 table 标签下指定 即可

如果想要改全局就没那么容易了.

官方文档:
http://www.mybatis.org/genera...

查看配置文档发现有一个 javaTypeResolver 标签, 有一个生成器的默认实现

package org.mybatis.generator.internal.types;

import java.math.BigDecimal;
import java.sql.Types;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;

import org.mybatis.generator.api.IntrospectedColumn;
import org.mybatis.generator.api.JavaTypeResolver;
import org.mybatis.generator.api.dom.java.FullyQualifiedJavaType;
import org.mybatis.generator.config.Context;
import org.mybatis.generator.config.PropertyRegistry;
import org.mybatis.generator.internal.util.StringUtility;

/**
 * 
 * @author Jeff Butler
 */
public class JavaTypeResolverDefaultImpl implements JavaTypeResolver {

    protected List warnings;

    protected Properties properties;

    protected Context context;

    protected boolean forceBigDecimals;

    protected Map typeMap;

    public JavaTypeResolverDefaultImpl() {
        super();
        properties = new Properties();
        typeMap = new HashMap();

        typeMap.put(Types.ARRAY, new JdbcTypeInformation("ARRAY", //$NON-NLS-1$
                new FullyQualifiedJavaType(Object.class.getName())));
        typeMap.put(Types.BIGINT, new JdbcTypeInformation("BIGINT", //$NON-NLS-1$
                new FullyQualifiedJavaType(Long.class.getName())));
        typeMap.put(Types.BINARY, new JdbcTypeInformation("BINARY", //$NON-NLS-1$
                new FullyQualifiedJavaType("byte[]"))); //$NON-NLS-1$
        typeMap.put(Types.BIT, new JdbcTypeInformation("BIT", //$NON-NLS-1$
                new FullyQualifiedJavaType(Boolean.class.getName())));
                
等等等...

可以发现是把数据库类型和 JavaType 使用 map 映射起来了, 要是能改这个东西就好了
在网上搜索没有找到合适的扩展点, 在官方仓库中搜到了一点相关的东西

参考:
https://github.com/mybatis/ge...

如果想控制映射关系, 有两个方案

  1. 编写一个插件
  2. 扩展 JavaTypeResolverDefaultImpl 并更改 calculateJavaType 方法, 在 TypeResolver 配置自己的实现

显然第二个实现起来比较简单, 我们的要求不是很复杂, 不用修改 calculateJavaType, 所以可以直接覆盖
org.mybatis.generator.internal.types.JavaTypeResolverDefaultImpl#typeMap 中的映射关系

首先把 mybatis-generator 源码拉下来 ,打开
org.mybatis.generator.internal.types 包新建一个类, 继承原有的
JavaTypeResolverDefaultImpl, 然后在构造中覆盖原有配置

package org.mybatis.generator.internal.types;

import org.mybatis.generator.api.dom.java.FullyQualifiedJavaType;

import java.sql.Types;

public class MyJavaTypeResolverDefaultImpl extends JavaTypeResolverDefaultImpl {

    public MyJavaTypeResolverDefaultImpl() {
        super();
        //把数据库的 TINYINT 映射成 Integer
        super.typeMap.put(Types.TINYINT, new JdbcTypeInformation("TINYINT", new FullyQualifiedJavaType(Integer.class.getName())));
    }
}

完成以后整体 install 到本地, 拉下来的版本号是 1.3.7-SNAPSHOT, 注意改一下自己项目依赖的版本号
在生成配置文件中把 javaTypeResolver 修改成自己的实现类

 

这样的话生成代码时就会把数据库的 tinyint 变成 Java 中的 Integer

相关文章

《阿里巴巴 Java 开发手册》.PDF_阿里巴巴java书

资源名阿里巴巴Java开发手册作者阿里巴巴与全球Java社区开发者格式PDF出版年2020.8标签程序设计、Java推荐星级?????封面介绍《阿里巴巴 Java 开发手册》是阿里巴巴集团技术团队的集...

55万字!阿里内部最新最全Java面试进阶手册,能横扫99%的面试官

年底了,现在可以说是备战金三银四的最佳时候了。为了让大家能在面试中过关斩将,小编特地找了在阿里的朋友要了这份内部不外传秘籍:55万字Java面试手册。这份面试手册涉及的技术栈非常全面而且足够细致,内容...

字节Java全能手册火了!多线程/网络/性能调优/框架啥都有

前言在这个技术不断更新的年代,跟不上时代变化的速度就会被刷掉,特别是咱们程序员这一群体,技术不断更新的同时也要同时进步,不然长江后浪推前浪,前浪......一个程序员从一个什么都不懂的小白在学到有一定...

太牛逼了!阿里技术团队重磅开放《Java 开发手册》附下载地址

《阿里巴巴 Java 开发手册》的愿景是码出高效,码出质量。它结合作者的开发经验和架构历程,提炼阿里巴巴集团技术团队的集体编程经验和软件设计智慧,浓缩成为立体的编程规范和最佳实践。从严格意义上讲,《阿...

我肝了!这份《JAVA核心架构手册》

6月,生活工作渐渐步入正轨,但今年求职者,却没有往年顺利。昨天跟一位高级架构师的前辈聊天时,聊到今年的面试。有两个感受:一个是今年面邀的次数比往年要低不少;再一个就是很多面试者准备明显不足。要么,“知...

牛皮了,GitHub上还不错的Java Web开发手册,屌?

前言Java 是当今程序开发中最流行的编程语言之一,它不仅可以开发手机应用、桌面应用,而且越来越多地用于Java Web开发中,由于Java优越的跨平台特性,使其备受追捧。近年来,Java Web框架...