异常信息
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:
Mapper接口:
是一个字母的大小写引发的错误
解决方法
更改参数名使xml和Mapper接口里一致即可
总结与反思
一个字母的大小写错误,不仅仅是引发了BindingException异常,而且它还暴露了我极大的缺点:
- 命名不规范,Id还是ID,No还是NO,至今我还没弄明白到底该选择哪种命名
- 简单CV工程师:xml文件为了减少错误,直接从已有的SQL语句粘贴而来(NO),可是Mapper接口我却选择自己去写,采取了我的命名习惯(No)
一定要注意class与yml、xml之间的拼写错误!
技术不分领域,思想一脉相承,欢迎访问橙味菌的博客
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。