Mybatis 传入一个数组,判断某个字段在数组里

Mapper:

List<xxx> getAll(@Param("platformArray") String[] platformArray);

Sql:

select * from xx where
<if test="platformArray != null and platformArray.length > 0">
    Platform IN
    <foreach collection="platformArray" index="index" item="item"
             open="(" separator="," close=")">
        #{item}
    </foreach>
</if>

实际拼出来的sql:

select * from xx where Platform IN ("a","b")
### MyBatis判断数组是否非空的实现方法 在 MyBatis 的 XML 映射文件中,可以通过 `<if>` 标签来动态地构建 SQL 语句。对于数组类型的参数,可以使用 `test` 属性来进行非空判断。 #### 使用 `if` 标签判断数组是否非空 当传递的是 Java 数组时,可以利用如下方式: ```xml <select id="selectByArray" parameterType="int[]" resultType="YourResultType"> SELECT * FROM your_table WHERE 1=1 <if test="array != null and array.length > 0"> AND column_name IN <foreach item="item" collection="array" open="(" separator="," close=")"> #{item} </foreach> </if> </select> ``` 上述代码展示了如何检查名为 `array` 的整型数组是否既不是 `null` 又至少含有一个元素[^1]。 如果使用的数据结构是 List 类型,则相应的测试表达式应调整为: ```xml <if test="list != null and list.size() > 0"> <!-- Your logic here --> </if> ``` 这假设传入的对象是一个列表(List),并且只有在其不为空的情况下才会执行其中定义的操作[^2]。 另外一种常见的做法是在实体类或映射接口设置布尔属性用于指示特定字段是否,从而简化查询条件的编写。例如: ```java public class WhereMap { private Integer proId; public boolean isProIdPresent(){ return this.proId != null && !this.proId.equals(0); } } <!-- Corresponding mapper.xml snippet --> <if test="whereMap.isProIdPresent()"> AND pro_id = #{whereMap.proId} </if> ``` 这种方法不仅提高了可读性和维护性,还减少了重复编码的工作量[^4]。 最后得注意的一点是,在某些情况下可以直接调用工具函数如 Apache Commons Lang 库的 `isNullOrEmpty()` 方法来做更简洁的安全验证[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值