mybatis传参正常且直接运行sql能获得正确结果但通过mybatis却查询不到结果的原因:oracle数据库中使用了char类型的字段

问题:

在使用mybatis的过程中,多次检验传参、sql语句等查询条件,并未发现存在错误,直接执行后台日志中的sql也能够查到正确结果,但是后台mybatis返回的值一直是空。

原因:

经过测试发现是数据库表结构中使用了char作为字段类型,而参数的长度和char的长度不符。在oracle中如果char内容长度不够,那么会自动用空格补满。比如我们在char2中插入‘0’,那么数据库会自动补齐为‘0 ’,当我们从mybatis传参‘0’进行比较时,‘0’和‘0 ’不相同,返回值就会是空。

解决方法:

1.修改表结构或者传参的值,使两者长度适配

2.修改dao层的xml语句,去除多余的空格,例如:select * from tb2 where trim(tb2.id)=#{id}

 

posted @ 2018-12-17 16:22  意寒星荃  阅读(1997)  评论(0编辑  收藏  举报