Mybatis Generator将tinyint映射成Integer的解决办法

2024-08-27 15:38

本文主要是介绍Mybatis Generator将tinyint映射成Integer的解决办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境

Java:1.8+
mybatis:3.3.0
mybatis-generator-core:1.3.5

前言

今天遇到了这么一个错误:

TicketMonitorServiceImpl.personMonitorPage.error org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'TINYINT'.  Cause: java.lang.ClassNotFoundException: Cannot find class: TINYINTat org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:75)at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:368)at com.sun.proxy.$Proxy104.selectList(Unknown Source)at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:198)at org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:122)at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:64)at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)at com.sun.proxy.$Proxy181.selectPartUserIdByQO(Unknown Source)

也就是说,不能识别或者找到TINYINT; 我的dao层代码是用生成工具生成出来的;
字段 is_accept java类型是Byte, jdbcType类型是TINYINT;
刚开始,我以为是不能使用jdbcType:TINYINT,javaType:Byte这套组合.所以就想着换成Integer类型。
实际上,之所以报错的原因是:其实是我在XXXMapper.xml文件中写错了类型:

# 错误的写法
is_accept = #{accept,javaType=TINYINT}
# 正确应该是
is_accept = #{accept,jdbcType=TINYINT}

不过,既然遇到了,所以就顺道研究了下:1. tinyint如何转Integer的问题?2. tinyint(1)为什么又会转为Boolean?

将tinyint映射成Integer

先来看看MySQL的官方文档:

Java, JDBC and MySQL Types

下面这张图,是说,MySQL的数据类型,可能转为Java的类型有哪些~
在这里插入图片描述
这张图,是明细图,就明确的告诉你,MySQL的数据类型,一定会传为Java的哪个类型~
在这里插入图片描述
我们看到标红的地方,翻译过来就是:当字符类型为tinyint且长度为 1 时,会被转换成布尔类型。如果tinyInt1isBit取false时,则转Integer。

实际你会发现,即使设置了tinyInt1isBit=false,依然不会转Integer;
其实是因为mybatis,在tinyint(1)的情况下,映射成BIT
即:<result column="deleted" property="deleted" jdbcType="BIT" />
因为映射成了BIT类型,所以使用tinyInt1isBit=false参数当然不会起作用。
解法,看后面的tinyint(1) mybatis会生成jdbcType=BIT,导致转Integer失败的解法

解决tinyint转Integer的方法有两种:

方法一:继承插件接口JavaTypeResolverDefaultImpl

mybatis官方文档
在这里插入图片描述
在配置文件中有一个 <javaTypeResolver> 标签可以用来配置映射关系。而该标签有一个 type 属性。上图中的英文翻译过来就是:用户可以提供一个自定义的实现,该类必须实现JavaTypeResolver接口,且必须有一个共有的默认构造器,或者沿用默认值DEFAULT,将使用JavaTypeResolverDefaultImpl来进行映射;

package com.sgy;import org.mybatis.generator.api.dom.java.FullyQualifiedJavaType;
import org.mybatis.generator.internal.types.JavaTypeResolverDefaultImpl;import java.sql.Types;public class TinyIntJavaTypeResolver extends JavaTypeResolverDefaultImpl {public TinyIntJavaTypeResolver() {super();typeMap.put(Types.TINYINT, new JavaTypeResolverDefaultImpl.JdbcTypeInformation("TINYINT", new FullyQualifiedJavaType(Integer.class.getName())));}
}

因为我们实际项目开发中,使用的generator是以Maven插件的形式集成到项目中的,插件启动的时候并不会加载我项目中的类文件。故会报类无法加载的错误。解决方法就是将该类的依赖,添加到插件的依赖中。

pom.xml文件中,添加模块依赖。

<plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.2</version><dependencies><!--重点这里,将类所在的模块,引入进来,因为是本项目,所以排除掉全部的传递依赖--><!--重点这里,因为我的类TinyIntJavaTypeResolver写在server层,所以只添加server的依赖--><!--重点这里,即:yutao-server--><dependency><groupId>com.sgy</groupId><artifactId>yutao-server</artifactId><version>1.0.1-SNAPSHOT</version><exclusions><exclusion><groupId>*</groupId><artifactId>*</artifactId></exclusion></exclusions></dependency></dependencies><configuration><verbose>true</verbose><overwrite>true</overwrite><configurationFile>${basedir}/src/main/resources/mybatis_generator/generatorConfig-yt.xml</configurationFile></configuration>
</plugin>

接着在generatorConfig.xml文件中:

... ...
<!-- 数据库链接URL、用户名、密码 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"connectionURL="jdbc:mysql://localhost:3306/misstest"userId="root" password="rootroot">
</jdbcConnection>
<javaTypeResolver type="me.ele.bi.woos.utils.TinyIntJavaTypeResolver"><property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
... ...

自此,完毕,现在生成的代码就是可以将 tinyint映射成Integer的。

但是这种方式,对于tinyint(1)的情况是不行的,因为tinyint(1)的情况,在mybatis中,jdbcType被映射成了BIT类型,这里我们有两种改法:

tinyint(1) mybatis会生成jdbcType=BIT,导致转Integer失败的解法

①改法一:

public TinyIntJavaTypeResolver() {super();typeMap.put(Types.TINYINT, new JavaTypeResolverDefaultImpl.JdbcTypeInformation("TINYINT", new FullyQualifiedJavaType(Integer.class.getName())));//加一段bit的映射typeMap.put(Types.BIT, new JavaTypeResolverDefaultImpl.JdbcTypeInformation("BIT", new FullyQualifiedJavaType(Integer.class.getName())));
}

加一段bit的映射就可以了。

②改法二:

不设置tinyint(1),等于就是叫你别这样用了。或者考虑使用下面的方法二

方法二:在配置文件generatorConfig.xml中直接指定

这个就简单很多了

<table tableName="test" domainObjectName="Test" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"><columnOverride column="deleted" property="deleted" javaType="java.lang.Integer" /><columnOverride column="is_accept" property="isAccept" javaType="java.lang.Integer" />
</table>

重点要注意:是javaType="java.lang.Integer",即:javaType,不是配置jdbcType,两者千万别搞混了。

然后我们测试,生成文件看看:

生成的Mapper.xml:
在这里插入图片描述
生成的model是:

在这里插入图片描述

这样也就OK了。

总结

我们学到了,有两种方法可以将 tinyint 映射为 Integer。

方法一,继承JavaTypeResolverDefaultImpl接口的方式,比较通用。

方法二,在配置文件generatorConfig.xml中直接指定,这种方式简单,粗暴;只不过每次生成一张表,都需要进行配置(假设需要的话)。

最后,我最开始报错的原因,其实是我在XXXMapper.xml文件中写错了类型:

is_accept = #{accept,javaType=TINYINT}
# 正确应该是
is_accept = #{accept,jdbcType=TINYINT}

假设最开始我写对了,其实Java类型使用Byte,是没有问题的。

价值参考

5.5 Java, JDBC and MySQL Types

解决tinyint映射成boolean/byte的问题

解决Mybatis generatorConfig.xml将tinyint映射为Byte和Boolean

https://blog.csdn.net/yu542771572/article/details/116607642

这篇关于Mybatis Generator将tinyint映射成Integer的解决办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112086

相关文章

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Spring Boot结成MyBatis-Plus最全配置指南

《SpringBoot结成MyBatis-Plus最全配置指南》本文主要介绍了SpringBoot结成MyBatis-Plus最全配置指南,包括依赖引入、配置数据源、Mapper扫描、基本CRUD操... 目录前言详细操作一.创建项目并引入相关依赖二.配置数据源信息三.编写相关代码查zsRArly询数据库数

MySQL错误代码2058和2059的解决办法

《MySQL错误代码2058和2059的解决办法》:本文主要介绍MySQL错误代码2058和2059的解决办法,2058和2059的错误码核心都是你用的客户端工具和mysql版本的密码插件不匹配,... 目录1. 前置理解2.报错现象3.解决办法(敲重点!!!)1. php前置理解2058和2059的错误

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma