MyBatis中动态sql的模糊搜索foreach实现In集合的用法

Posted 公众号:霸道的程序猿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis中动态sql的模糊搜索foreach实现In集合的用法相关的知识,希望对你有一定的参考价值。

场景

在使用MyBatis的动态sql时,常见的是传递一个ID的数组,查询记录的

ID在这个数组中的记录和模糊搜索这两种场景。

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

模糊搜索的实现

mapper接口写法:

public List<KqDksz> selectKqDkszListBySx(String xm);

xml写法:

    <select id="selectKqDkszListBySx"  resultMap="KqDkszResult">
        <include refid="selectKqDkszVoJoinJibenXinXi"/>
        <where>
            <if test="xm != null  and xm != ‘‘"> and j.xm like concat(%, #{xm}, %)</if>
        </where>
    </select>

foreach实现in集合

mapper层接口写法:

public int deleteKqBcglXiangxiByIds(Long[] ids);

xml写法:

    <delete id="deleteKqBcglXiangxiByIds" parameterType="String">
        delete from kq_bcgl_xiangxi where ID in 
        <foreach item="id" collection="array" open="(" separator="," close=")">
            #{id}
        </foreach>
    </delete>

注意:

这里的参数为数组参数,就需要把collection属性设置为array

但是这是数组默认的名字,推荐使用@Param来指定参数的名字,这时collection就设置为通过@Param注解指定的名字。

比如:

 public List<KqKqrysz> selectKqKqryszListBySx(@Param("badao")Long[] bmids);

对应的是

             <foreach collection="badao" item="item" open="(" separator="," close=")">
               ${item}
             </foreach>

 

如果这里不是数组而是list的话,那么其collection默认的就是list而不是array了。

以上是关于MyBatis中动态sql的模糊搜索foreach实现In集合的用法的主要内容,如果未能解决你的问题,请参考以下文章

Mybatis 的 foreach 批量模糊 like 查询及批量插入

Mybatis 的 foreach 批量模糊 like 查询及批量插入

Mybatis 的 foreach 批量模糊 like 查询及批量插入

Mybatis 的 foreach 批量模糊 like 查询及批量插入

MyBatis参数传入集合之foreach动态sql

Mybatis单表多表查询,动态SQL使用