项目场景:
分了一个小任务,就是在后端逻辑层的一个方法里的SQL语句里在拼接三个判断语句。
问题描述:
当时,也没考虑太多,根据需求,就直接写了。如下:
if(dto.getxxx() == 1){
sql.append(" and xxx = 1 ");
}
结果可想而知,报错了。
deBug了一下,java.lang.reflect.InvocationTargetException,报null了。
我有点不明白为什么报空,我想为什么上面那个拼接也是这么写的为啥不报错。心里大呼神奇。
原因分析:
我不清楚怎么错了,但是我意识到应该加个判空,然后我加了判空,可以了。
我想错误原因是没有添加判空。
if(dto.getxxx() != null && dto.getxxx() == 1){
sql.append(" and xxx = 1 ");
}
第二天:
凯哥审查我写的代码,评价是: 这样写也行。(作者心里其实知道自己的技术不太好)然后我跟凯哥说为啥这样写,巴拉巴拉。后来凯哥跟我点开 实体类让我看了一下xxx这个字段,
private Integer xxx;
这个字段是包装类型,这是一个对象。它比较的时候得先教研判断是否为null,不校验的话可能会报空指针。
一听到这我不禁脸红,打好基础可见是多么重要。
欢迎大家多多指教。