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

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

问题描述

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

数据库字段

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

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

Mybatis查询语句

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

业务逻辑查询方法

java 复制代码
List<Map> answerList = essenceAnswerMapper.findByAnswerDateV2(startTime, endTime, Long.parseLong(id), subjectIdList);

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

这里可以看到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

再次启动程序测试

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

方案二

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

同样解决了问题

方案三

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

到这里,关于Mybatis Map接收数据tinyint(1)类型错误问题就处理完了。

相关推荐
追随者永远是胜利者几秒前
(LeetCode-Hot100)32. 最长有效括号
java·算法·leetcode·职场和发展·go
lifallen1 分钟前
CDQ 分治 (CDQ Divide and Conquer)
java·数据结构·算法
笨蛋不要掉眼泪8 分钟前
OpenFeign远程调用详解:声明式实现、第三方API集成与负载均衡对比
java·运维·负载均衡
yaoxin52112312 分钟前
326. Java Stream API - 实现自定义的 toList() 与 toSet() 收集器
java·开发语言
追随者永远是胜利者13 分钟前
(LeetCode-Hot100)31. 下一个排列
java·算法·leetcode·职场和发展·go
Cosmoshhhyyy18 分钟前
《Effective Java》解读第40条:坚持使用Override注解
java·开发语言
番茄去哪了1 小时前
在Java中操作Redis
java·开发语言·数据库·redis
无心水1 小时前
6、合纵连横:开源快速开发平台全解析与自建平台架构实战【终篇】
java·后端·科技·spring·面试·架构·开源
ritxgt0061 小时前
Linux下安装Nginx服务及systemctl方式管理nginx详情
java
山北雨夜漫步1 小时前
点评day02 商户缓存
缓存·mybatis