一个馒头引发的血案记BindingException的产生及解决过程
一. 业务场景
前几天壹哥带学生做一个项目,需要更新数据库中的车辆信息表,具体需求是要根据指定车辆的设备id(编号和设备ID均非主键)来更新车辆信息。壹哥要求学生们用Mybatis进行实现,所以就在对应的Mapper.xml文件中自定义SQL语句。结果有个学生在调用对应接口时爆出了一个BindingException异常,一下子就造成了整个模块崩溃,但他不知道这个异常该怎么解决,于是就慌慌张张地跑来问壹哥。其实我们在学习的时候,很多初学者都会遇到一些奇葩的问题而不知道怎么解决。
那么接下来,壹哥就以Mybatis中的这个常见异常为例,来带大家分析开发时出现异常之后该如何快速定位及解决问题,这样以后再遇到类似问题时,大家就知道该怎么解决了。
壹哥 提醒,不要让同一个问题困扰你两次哦! 二. 异常信息
我们先来看看这个异常是什么。org.apache.ibatis.binding.BindingException nested exception is org.apache.ibatis.binding.BindingException:Parameter "carNo" not found. Available parameters are [cardNo, devId, param1, param2]
很多同学在初次使用Mybatis时,其实很容易会遇到上面的这个异常。遇到了问题不可怕,我们想办法解决就是了。但有些同学一看到密密麻麻的英文单词,几乎一个都不认识,脑袋嗡一下子就炸了,到底哪里出错了,出了什么错,啥也不知道,反正就知道自己的代码报错了,剩下就不知所措了。
壹哥在这里告诉大家,遇到问题千万不要紧张。如果你的单词量不行,可以使用有道翻译对照查看错误意思,然后慢慢积累这些单词就记住了。其实Java里的常用单词就那么几个,天天看就知道是啥意思了,我们开发时其实也不需要你背写单词。
上面的异常信息,咱们根据字面意思来理解就是产生了一个绑定异常,而后面的详细描述是说参数 carNo找不到.......既然已经知道了这个错误,那就继续往下看具体的分析过程吧! 三. Mybatis使用须知
在解决异常之前,壹哥先来带各位复习一下Mybatis的使用须知:1). 首先定义的接口方法名要和XxxMapper.xml文件中的id保持一致; 2). 建议接口名和mapper映射文件名称一致; 3). mapper映射文件中的namesapce必须是接口的全限定名称; 4). 建议接口文件和mapper映射文件的目录结构一致; 5). 接口中如果用了参数绑定@Param,需要查看映射文件的占位符内容是否和它一致。四. 原因排查
复习了上面的Mybatis使用须知之后,你现在是否已经知道上面的异常是怎么产生的了?其实控制台里的异常信息已经把原因说得很清楚了:Parameter "carNO" not found. Available parameters are [carNo, devId, param1, param2] ,
这里表示没找有到占位符表示的参数 #{carNO},能用的参数有carNo、devId等,这里明显就是发生了拼写错误。我们仔细检查核对一下发生异常之前,MyBatis中的XML文件内容: update car set devId = #{devId} where car_no = #{carNO}
我们发现,原始的XML映射文件里面#{carNO}占位符使用的carNO,即NO都是大写字母!!!然后我们再来看看对应的Mapper接口代码:int updateDevIdByCarNo(@Param("devId") String devId,@Param("carNo")String carNo);
注意看,这里参数绑定里面No的o是小写字幕,就是这样一个很小的细节,因为学生的粗心大意导致了上面的绑定错误!
也就是说,上面的异常是由一个字母的大小写不匹配而引发的!无语!是不是太不应该出现这种错误了呢?其实很多人在学习编程时所犯的错误,绝大多数都是因为马虎造成的! 五. 解决办法
其实解决办法很简单,只需要将XML文件中的参数名和Mapper接口里的参数名保持一致即可!比如两者都改成carNO!六. 总结与反思
本案例中的异常,是因为一个字母的大小写不匹配而导致的错误,这不仅仅引发了BindingException异常,同时还暴露了我们学习时存在的极大缺点:1). 代码命名不规范,Id还是ID,No还是NO,在项目中要保持统一的风格; 2). 合理CV:为了减少XML文件中出现不必要的错误,可以直接从已有的SQL语句中把参数粘贴过来(NO); 3). 一定要注意接口与XML文件之间的拼写一致性!
本案例中的异常真可以说是"一个馒头引发的血案",一个小小的拼写错误也可以引发大故障,所以大家在开发时一定要仔细哦!
现在你知道异常该怎么解决了吗?如果还有什么问题,可以在评论区给壹哥留言哦。
消防主机操作和火警处理方法一火警处理当发生火警时,首先应按消音键中止警报声。然后应根据控制器的报警信息检查发生火警的部位,并去现场确认是否有火灾发生。(一)若确认有火灾发生应根据火情采取相应措施。(1)启动
2019消防知识点灭火基本原理与方法灭火的基本原理与方法1冷却灭火对于可燃固体,将其冷却在燃点以下对于可燃液体,将其冷却在闪点以下,燃烧反应就可能会中止。用水扑灭一般固体物质引起的火灾,主要是通过冷却作用来实现的,水
618首战告捷不是每款都会成为溢价爆品,华为OPPO最值得一看随着公共卫生环境的改善,中国人民的消费力要再次释放,报复性的消费如期如愿地到来,在618年中大促上可谓展现的淋漓尽致。仅开场1小时,京品家电成交额便实现同比增长5倍,天猫商品订单量
自动射流灭火装置(自动消防炮)应用误区及解决方案一小流量自动消防炮灭火装置(自动射流灭火装置),仅适应于小面积的中庭(或大堂)等民用建筑室内场所,设计流量可参照自动喷水灭火系统设计规范施行。室内应用的自动消防炮灭火装置(自动射流
带你走进吉祥鲜商城随着互联网的发展,快捷便利优选成为了重中之重,而东三省农产品信息化程度低,大部分供应商依旧采取老式销售模式,无法满足农产品消费者的需求,所以针对现存问题,我们研发了农产品电商平台吉
地方产业冷知识你get了吗?来京东一起寻宝前阵子有人总结了一份地方产业冷知识在网络上火了,几乎没什么名气的小镇,却在某个品类里满足了全国甚至全世界超过一半的制造需求。这些冷知识引发了众多网友的讨论,很多人还在评论里补充。近
如何降低分拣损耗?随着我国经济的不断发展,人们对食物的需求已不足以填饱肚子,食物的质量已成为每个人都关心的问题。许多消费者开始厌倦点餐的生活,生活的压力让很多人觉得,回家做饭是一个减压的过程,自己喜
上幼儿园前应该学习什么?这几点最适合,建议收藏同样的老师,同样的教材,为什么一年级的学生成绩会有差距?为什么别人家的小孩思维这么敏捷,想象力这么丰富?可能有爸妈认为是幼儿园的优劣导致的差异。其实不然,幼儿园的教育只占部分因素,
消防知识点学习技巧(4)一扎实巩固的基础阶段对于2018一级消防工程师考试,基础阶段的学习可谓是重中之重,不论学习的时间有多么紧张,一定不能错过扎实基础的学习。那么如何展开基础阶段的学习呢?其实基础学习就
消防知识点记忆技巧(1)消防考试的知识点内容繁杂,需要坚持每天复习,温故而知新,在学习新知识的同时,考生也要保证每天留出一定的时间来复习。以下是小编为大家整理的消防知识点记忆技巧,希望对大家有帮助。消防每
消防知识点备考技巧(3)1首先必须清楚国家对于消防考试的整体形势和规划,了解消防工程师的市场需求,根据国家的相关权威数据做出明确的市场评估,你才会知道你考取的证书有多大价值2必须明确的知道自己的学习能力如