mybatis/JDBC读取mysql数据库中CHAR(1)类型数据为空

本文探讨了一种在特定MySQL版本及JDBC配置下,CHAR(1)类型字段数据读取为空的现象,并提供了一种通过将字段转换为CHAR(2)类型来规避该问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

同一个select语句中,CHAR(1)类型的字段读取的数据为空,其他类型的字段包括CHAR(2)类型的都能读出正确的数据,检查mysql里面的数据,数据都不为空。
这可就奇怪了,本机装了一个mysql5.7,发现没有这样的问题。可是服务器上的数据库不能随便改啊。
直接写一个用JDBC的demo程序读数据库,CHAR(1)类型的字段数据还是为空,还是同样的问题,看来不是mybatis的问题了。目测是mysql版本的问题或者JDBC的问题。

解决方案

既然CHAR(2)类型的字段没有问题,那就使用concat()试试:

select concat(column_name, '#') as column_name from table_name where ...

这样colunm_name字段就是CHAR(2)了,第二位固定是’#’,就这样绕过去了。
还是想知道到底是为什么会出现那个问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值