本文主要是介绍mybatis 传入null值解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前端传入两个值,如果其中一个为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;}
问题解决,希望对大家有帮助!
这篇关于mybatis 传入null值解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!