mybatis 之 if test 条件

本文探讨了MyBatis中if标签使用时遇到的问题及解决方案,包括字符串比较失效及Integer类型参数为0时不生效的情况,并提供了正确的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题1   Mybatis if test 字符串比较不生效

<if test="publishType!='2'">
      and t.status='3'
      and t.has_attachment='YES'
</if>

其中publishType为传来的String类型参数,想比较其不等于字符串2,但是判断不生效

原因:

单引号是char类型,双引号是string类型!

char表示字符,定义时使用用单引号表示,只能存储一个字符。

而String表示字符串,定义时使用双引号表示,可以存储0个或多个字符,其实string类型就是char类型的数组表现形式。

所以'2'被认为是char类型,和String类型不相等

1.改成双引号

<if test='publishType!="2"'>
    and t.status='3'
    and t.has_attachment='YES'
</if>


2.加.toString()方法

<if test="publishType!='2'.toString()">
      and t.status='3'
      and t.has_attachment='YES'
</if>


 

问题2  mybatis 之 if test 条件,Integer类型 ,参数为0时,查询条件未输出。如,当 tagtype值为0(Integer),查询条件没有拼接 and tagtype=0。传入其他值(1,2,3...)都正常

一、mybatis 配置

    <!-- Where查询条件 -->

    <sql id="whereSQL">

        <if test=" null != id">

            AND id =#{id}

        </if>

        <if test=" null != tagname and '' != tagname">

            AND tagname LIKE '%${tagname}%'

        </if>

        <if test=" null != tagtype and '' != tagtype">

            AND tagtype = #{tagtype}

        </if>

    </sql>

tagtype 表中类型Integer

 

解决方法:

<if test=" null != tagtype and '' != tagtype">

            AND tagtype = #{tagtype}

</if>

修改为

<if test=" null != tagtype and '' != tagtype or 0 == tagtype">

            AND tagtype = #{tagtype}

</if>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值