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}
【mybatis传参正常且直接运行sql能获得正确结果但通过mybatis却查询不到结果的原因:oracle数据库中使用了char类型的字段...】转载于:https://www.cnblogs.com/notACoder/p/10132201.html
推荐阅读
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- mybatisplus如何在xml的连表查询中使用queryWrapper
- mybatisplus|mybatisplus where QueryWrapper加括号嵌套查询方式
- MybatisPlus|MybatisPlus LambdaQueryWrapper使用int默认值的坑及解决
- MybatisPlus使用queryWrapper如何实现复杂查询
- iview|iview upload 动态改变上传参数
- MyBatis|MyBatis Generator配置
- Mybatis|Mybatis Plus 分页插件
- Mybatis(一)
- 被mybatis-generator-gui-0.6.1报错坑到的那些事(二)