异常记录——使用Mybatis报BindingException

异常记录——使用Mybatis报BindingException

异常信息

org.apache.ibatis.binding.BindingException

nested exception is org.apache.ibatis.binding.BindingException: Parameter 'deviceNO' not found. Available parameters are [deviceNo, deviceId, param1, param2]复制代码

场景回溯

业务场景:车辆表,需要更新指定编号车辆的设备Id(编号和设备ID均非主键),因而在对应的mapper.xml中自定义了SQL语句,结果调用对应接口时爆出异常

当然可以直接使用Mybatis-plus的EntityWrapper,这样做虽然方便,但是第一影响性能,第二造成职责划分不清(SQL的拼装属于dao层,它从来就不该在Service层完成)

原因排查

apache的ibatis将原因说的很清楚:Parameter ‘deviceNO’ not found. Available parameters are [deviceNo, deviceId, param1, param2] ,没找到xml里使用占位符表示的参数(#{deviceNO}),能用的参数有deviceNo、deviceId等,很明显是发生了拼写错误

xml:

异常记录——使用Mybatis报BindingException

Mapper接口:

异常记录——使用Mybatis报BindingException

是一个字母的大小写引发的错误

解决方法

更改参数名使xml和Mapper接口里一致即可

总结与反思

一个字母的大小写错误,不仅仅是引发了BindingException异常,而且它还暴露了我极大的缺点:

  1. 命名不规范,Id还是ID,No还是NO,至今我还没弄明白到底该选择哪种命名
  2. 简单CV工程师:xml文件为了减少错误,直接从已有的SQL语句粘贴而来(NO),可是Mapper接口我却选择自己去写,采取了我的命名习惯(No)

一定要注意class与yml、xml之间的拼写错误!

技术不分领域,思想一脉相承,欢迎访问 橙味菌的博客

本文由博客一文多发平台 OpenWrite 发布!

原文 

https://juejin.im/post/5e15753c5188253a8e632296

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » 异常记录——使用Mybatis报BindingException

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址