同一个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)了,第二位固定是’#’,就这样绕过去了。
还是想知道到底是为什么会出现那个问题。