今天查询数据的时候,sql是这样的 select * from table where pkey=‘xx’ and version = ‘1’ and system =‘1’ ; 在Oracle查询出来没有问题,但是放在Mapper文件里,用Mybatis查询出来为空。返回类型和参数都没有问题,debug也跑了没有发现问题。
后来发现
我的version字段,是char(4),然后我mapper里面定义的是varchar,但是这不是最影响的问题,主要原因是因为,我传的version是1个字符,Oracle会在你char类型不足的时候,用空格补齐。导致参数是这样version =‘1 ‘,所以会匹配不到。
吐槽一下IDEA,为什么debug跑的时候,参数显示和eclipse不一样,eclipse能够吧空格打印出来,而IDEA debug不会显示空格