使用动态sql中的if条件判断各种使用方式

使用中踩的坑记录一下(使用动态sql中的if条件判断各种使用方式)

<mapper namespace="dynamic">
 
    <resultMap id="userMap" type="com.soft.test.model.User">
        <id column="id" property="id"/>
        <result column="username" property="username"/>
        <result column="password" property="password"/>
        <result column="create_date" property="createDate"/>
    </resultMap>
 
    <!--***if 标签使用类似html的C标签的if 在此处应该是and 或者使用or来代替&&||*** -->
    <select id="selectUseIf" parameterType="com.soft.test.model.User" resultMap="userMap">
        select * from t_user where
        <if test="id != null and id != ''">
            id=#{id}
        </if>
        <if test="username != null and username != ''">
            and username like concat('%',#{username},'%')
        </if>
        <if test="password != null and password != ''">
            and password=#{password}
        </if>
    </select>
    
</mapper>

插入链接与图片

图片:
此图片仅供参考!!!

mybatis的if判断语句其实跟el表达式的if条件判断有些类似。

例如:

1 如果参数为数字类型的时候没有特俗需求的情况只需要判断是否为null即可。

例如:

如果有特俗需求,例如判断是否大于某个数的时候才行。只需要加上对应的条件判断即可

例如:

mybatis对于这种大于小于等等还有另一种形式。

例如:

对应关系:


gt            对应             >

gte         对应              >=

lt             对应              <(会报错  相关联的 "test" 属性值不能包含 '<' 字符)

lte          对应               <=(会报错  相关联的 "test" 属性值不能包含 '<' 字符)

2 如果为字符串类型

2.1 如果不需要过滤空串的情况 仅仅判断null即可

例如:

2.2 如果需要过滤空串,添加空串判断即可 不支持 && 所以这里用 and or || 来做逻辑与或的判断

例如: 或者

2.3 如果判断字符串是否已某个特俗字符开头,结尾等。直接调用String的对应方法即可

例如:

2.4 是否是某个特定字符串,某些业务有此需要。

例如: 或者

注意:

这种形式的写法在参数类型是字符串的时候是没有问题的,

但是参数类型为非字符串类型的时候就需要写成

仅仅写成也会有很大可能会挂。

也许你会说非字符串的为什么要写成这样。这就要看特俗需要了。

例如:某一个sql片段是公用的,


该片段更新条件也用,但是当你需要将某一个字段更新成null的时候怎么办。

这个时候就可以通过传入一个特定的字符串来弄。当传入的字符串为特定字符串的时候就更新该字符串为null。

xxx=null

当然这样子貌似date型会挂。

通过 2.2 也可以看出mybatis对于字符串的相等不相等的判断也是有对应的特俗操作符的。


eq 对应 ==

neq 对应 !=


当然还可以看出来if的条件判断test是支持对象自身方法调用的,即使是自己写的方法,可以自己尝试。当然下面会有例子。

例如:里面可以用‘xxxx’.equals(xxxx) 字符串的比较两个字符串方法

xxxx.indexOf('ss') 判断字符串里面是否包含某个字符等等  

3 判断list是否为空

上面说过,if条件判断可以直接调用对象自身的方法进行逻辑判断,所以list判空。可以调用.size()>0或者.isEmpty()

例如: ,

4 map参数同同理 取值的话 map.key(map中的key名字)即可

此文摘要:鸣谢sumlen

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以回答你关于MyBatisif标签的使用方式。 在MyBatis,if标签通常用于动态生成SQL语句。它可以用来判断某个字段是否为空,从而根据不同情况生成不同的SQL语句。 以下是一些使用if标签的示例: 1. 判断一个参数是否为null或空字符串: ``` <select id="selectUser" parameterType="java.lang.String" resultType="User"> SELECT * FROM users <where> <if test="username != null and username != ''"> AND username = #{username} </if> </where> </select> ``` 这个例子,如果传入的username参数不为null或空字符串,则会将其加入到SQL语句,生成类似于“AND username = 'xxx'”这样的条件语句。 2. 判断一个对象的某个属性是否为null: ``` <select id="selectUser" parameterType="User" resultType="User"> SELECT * FROM users <where> <if test="email != null"> AND email = #{email} </if> </where> </select> ``` 这个例子,如果传入的User对象的email属性不为null,则会将其加入到SQL语句,生成类似于“AND email = 'xxx'”这样的条件语句。 3. 判断一个集合是否为空: ``` <select id="selectUser" parameterType="java.util.Map" resultType="User"> SELECT * FROM users <where> <if test="ids != null and ids.size() > 0"> AND id IN <foreach item="id" collection="ids" open="(" separator="," close=")"> #{id} </foreach> </if> </where> </select> ``` 这个例子,如果传入的Map对象包含一个名为ids的集合属性且不为空,则会将其加入到SQL语句,生成类似于“AND id IN (1,2,3)”这样的条件语句。 以上是一些if标签的使用示例,希望能对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值