Caused by: org.apache.ibatis.ognl.OgnlException: source is null for getProperty(null, "id")

    OgnlException这个Mybatis的错误其实就是包装了Java的NullPointException异常。所以显而易见,就是你的这个属性是空的。但是前几天我在用Mybatis时,出现了这个错误,却没有查出原因。于是我查找了****里面的一篇博客才发现其实问题很简单。博客地址:https://blog.****.net/qq_32331073/article/details/76272110

    我觉得这种原因就有点类似我们在写java程序的时候,有一个类A,而这个类里面还有一个类对象B。你新建了一个类A,它里面的类对象B并没有赋值,即为null。而你却直接通过A.get的方法,得到类对象B,然后在调用它里面的属性。这时就会导致NullPoint异常。

  1. public static void main(String[] args) {
  2. //AffairVo代表类A 它的属性Affair代表类B
  3. AffairVo A=new AffairVo();
  4. //设置类B为null
  5. A.setAffair(null);
  6. //在它里面的类B为空时,继续调用类B的属性时,则为空
  7. System.out.println(A.getAffair().getUserid());
  8. }

    而我Mybatis里面xml映射出现的错误跟其一致,就是在类B为空时,继续调用类B里面的属性,这就会导致Mybatis的OgnlException异常。

    解决方案1:

    在调用类B里面的属性时,先判断类B是否为null

  1. <if test="affairvo.affairmodel!=null ">
  2. <!-- 这里多添加一个判断条件是因为如果affairmodel这个对象为空时,继续获取里面的属性就会报错 -->
  3. <if test="affairvo.affairmodel.affairmodelname!=null">
  4. and affairmodel.affairModelName like CONCAT(CONCAT('%', #{affairvo.affairmodel.affairmodelname}), '%')
  5. </if>
  6. </if>

    解决方案2:

    在创建类A时的同时,也将类B new()出来。接着赋值给类A。防止类B为空。   


    如果看不懂上面的解析,可以看看下面我诱发错误的代码截图

    1. 错误提示:

    Caused by: org.apache.ibatis.ognl.OgnlException: source is null for getProperty(null, "id")


     2. XML配置

    Caused by: org.apache.ibatis.ognl.OgnlException: source is null for getProperty(null, "id")


    3. 对应的实体类

   Caused by: org.apache.ibatis.ognl.OgnlException: source is null for getProperty(null, "id")