登录
首页 >  数据库 >  MySQL

解决jdbcTemplate和jpa查询TINYINT(1)返回BOOLEAN的问题

来源:SegmentFault

时间:2023-02-17 10:49:38 210浏览 收藏

小伙伴们对数据库编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《解决jdbcTemplate和jpa查询TINYINT(1)返回BOOLEAN的问题》,就很适合你,本篇文章讲解的知识点主要包括MySQL、Java、jpa、jdbctemplate。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

问题背景

在项目中使用jpa和jdbcTemplate时,发现当对Tinyint类型的数据进行查询时,会被当作boolean类型返回。
而在项目中,我们使用了大量的Tinyint来做枚举值,被当作布尔类型返回后,造成了程序的异常。

status TINYINT(1)  NOT NULL DEFAULT 0;

分析

在mysql的官网 numeric-type-overview 这篇文档里面写到

BOOL, BOOLEAN

These types are synonyms for TINYINT(1). A value of zero is considered false. Nonzero values are considered true

也就是说,在mysql中对

TINYINT(1)
BOOLEAN
的处理是一样的。

解决

查了不少文档,都是对

jpa
或者
jdbcTemplate
的查询方法进行扩展,在返回的数据进行Mapper匹配时,判断如果是TINYINT类型,就作特殊处理。
虽然这样能解决问题,但像这样普遍的问题,我相信mysql肯定有过考虑,然后在mysql的官方文档里面发现了这个配置
The data type returned for TINYINT(1) columns when tinyInt1isBit=true (the default) can be switched between Types.BOOLEAN and Types.BIT using the new configuration property transformedBitIsBoolean

也就是说,当你对mysql Connector设置了

tinyInt1isBit=true
后,它会将
TINYINT(1)
当作
BIT
也就是
Types.BOOLEAN
来处理。而且这个设置是默认开启的。那是不是设置为false后反过来呢?

于是在jdbc url后面添加了

?tinyInt1isBit=true
,问题解决

理论要掌握,实操不能落!以上关于《解决jdbcTemplate和jpa查询TINYINT(1)返回BOOLEAN的问题》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表