Mybatis Map接收数据tinyint(1)类型错误

简介: 简要讲述Mybatis使用Map接收返回数据时,tinyint(1)类型数据返回类型错误

问题描述

Mybatis开发过程中,使用Map接收返回数据时发现tinyint(1)类型字段自动转换成了Boolean类型,导致查询的数据出现问题

数据库字段

数据库表中字段为类型为tinyint(1)

`online_status` tinyint(1) DEFAULT '1' COMMENT '上线状态:1上线 0下线'

image.png

Mybatis查询语句

Mybatis查询语句通过Map接收返回数据

image.png

业务逻辑查询方法

List<Map> answerList = essenceAnswerMapper.findByAnswerDateV2(startTime, endTime, Long.parseLong(id), subjectIdList);

下面我们debug一下Map返回数据中对应online_status字段的返回值

image.png

这里可以看到tinyint(1)类型的字段`online_status` 值已经被转成了Boolean,而我们想要的实际是数据库原始字段的 0 1 值。

问题处理

方案一

在数据库链接后面加上tinyInt1isBit=false,比如

jdbc:mysql://192.168.6.207:3306/ei_answer_syn?useUnicode=true&characterEncoding=utf8\
  &zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8tinyInt1isBit=false

再次启动程序测试

image.png

根据debug看到的结果,字段`online_status`的返回值已经是正确的了,关于数据库连接增加的tinyInt1isBit=false说明可以参考Mysql官方文档:https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-reference-type-conversions.html 文档中关于这一块有明确的说明

image.png

方案二

改写sql,将对应的tinyint(1)字段增加判断IFNULL(ea.online_status,1) 其中默认值主要参考表设计时的默认值,或者是不影响业务逻辑的默认值都可以,数据库中这个字段的默认值是1,所以我这里就默认为1,`online_status` tinyint(1) DEFAULT '1' COMMENT '上线状态:1上线 0下线'

image.png

同样解决了问题

方案三

更改数据库字段tinyint(1)为tinyint(>1),这样查询过程中通过Map接收返回数据时也不会自动转换成Boolean类型了

image.png

相关文章
|
3月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
304 1
|
3月前
|
存储 Java Go
【Golang】(3)条件判断与循环?切片和数组的关系?映射表与Map?三组关系傻傻分不清?本文带你了解基本的复杂类型与执行判断语句
在Go中,条件控制语句总共有三种if、switch、select。循环只有for,不过for可以充当while使用。如果想要了解这些知识点,初学者进入文章中来感受吧!
194 1
|
5月前
|
SQL Java 数据库连接
MyBatis的配置文件中定义类型别名(type aliases)的技巧。
类型别名提供了一种便捷的方式来引用复杂的全限定类名。通过使用 `<package>`标签进行自动扫描或使用 `<typeAlias>`标签手动指定,可以在整个MyBatis配置中提高清晰度和维护性。无论是简化mapper文件中的配置,还是提高整体的配置可读性,类型别名都是一个非常有用的配置工具。
258 0
|
Java 数据库连接 数据库
mybatis查询数据,返回的对象少了一个字段
mybatis查询数据,返回的对象少了一个字段
1180 9
|
SQL Java 数据库连接
【潜意识Java】深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
2345 1
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
2086 5
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
645 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
SQL Java 数据库连接
mybatis使用四:dao接口参数与mapper 接口中SQL的对应和对应方式的总结,MyBatis的parameterType传入参数类型
这篇文章是关于MyBatis中DAO接口参数与Mapper接口中SQL的对应关系,以及如何使用parameterType传入参数类型的详细总结。
466 10
|
Java 数据库连接 测试技术
SpringBoot 3.3.2 + ShardingSphere 5.5 + Mybatis-plus:轻松搞定数据加解密,支持字段级!
【8月更文挑战第30天】在数据驱动的时代,数据的安全性显得尤为重要。特别是在涉及用户隐私或敏感信息的应用中,如何确保数据在存储和传输过程中的安全性成为了开发者必须面对的问题。今天,我们将围绕SpringBoot 3.3.2、ShardingSphere 5.5以及Mybatis-plus的组合,探讨如何轻松实现数据的字段级加解密,为数据安全保驾护航。
1296 1
|
SQL Java 数据库连接
Mybatis中传入不同类型的值处理方案
这篇文章讲述了在Mybatis中如何处理传入不同类型参数的情况,包括单个值、列表及Map等,并提供了相应的XML映射和Java代码示例。
550 0