前端传入两个值,如果其中一个为null时,很多时候我们都很困惑,明明传入的是null,为啥mybatis 的xml文件中的if条件判断无效?
public String getPersonInfo(@PathParam("Name") String Name, @PathParam("IDCard") String IDCard)
dao层:
public List<Map> getPersonInfo(@Param("name") String name, @Param("idcard") String idcard);
xml文件内容:
<if test="name == null or name == '0'.toString()">
<![CDATA[ and (b.identity_id = #{idcard,javaType=String,jdbcType=VARCHAR})
group by name,id_card,birthTime,sex ]]>
</if>
每次执行都是失败的,网上很多都说要在dao层添加@param注解和xml文件内容中要加入jdbcType类型就能解决,最后还是没解决
其实还有一个点忽略了,就是传入时的null值其实是个字符串null,根本就不是null,它是个字符串null
if (Name == null || "null".equalsIgnoreCase(Name)) {
Name = null;
}
if (IDCard == null || "null".equalsIgnoreCase(IDCard)) {
IDCard = null;
}
问题解决,希望对大家有帮助!