Mybatis中List传值

Mybatis遇到List传值时常用方法。

1. List<E>,E为基本数据类型和String

 Mapper类文件:
List<User> selectByIds(List<String> userList);
       
  Mapper.xml文件:
  <select id="selectByIds" parameterType="java.lang.String" resultType="com.example.demo.dto.User">
     SELECT id,name,note from USER where id in
      <foreach collection="list" separator="," open="(" close=")" item="id">
       #{id}
      </foreach>
   </select>

测试结果:

2. List<E>,E为Object对象

  **2.1 不配合@param使用**

  Mapper类文件:
  List<User> selectUser1(List<User> userList);

  Mapper.xml文件:
  <select id="selectUser1" parameterType="java.util.List" resultType="com.example.demo.dto.User">
    SELECT id,name,note from USER where id in
    <foreach collection="list" separator="," open="(" close=")" item="user">
        #{user.id}
    </foreach>
   </select>    

测试结果:

  **2.2 配合@param使用,自定义参数名**

  Mapper类文件:
  List<User> selectUser2(@Param("userList") List<User> userList);

  Mapper.xml文件:
   <select id="selectUser2" parameterType="java.util.List" resultType="com.example.demo.dto.User">
    SELECT id,name,note from USER
    where id in
    <foreach collection="userList" separator="," open="(" close=")" item="user">
        #{user.id}
    </foreach>
   </select>

测试结果:

3. Map<k,V>,V为List对象

  **3.1 不配合@param使用**

  Mapper类文件:
  List<User> selectByMap1(Map<String,List<User>> paramMap);

  Mapper.xml文件:
  <select id="selectByMap1" parameterType="java.util.Map" resultType="com.example.demo.dto.User">
    SELECT id,name,note from USER
    where id in
    <foreach collection="userMap" separator="," open="(" close=")" item="user">
        #{user.id}
    </foreach>
</select>

测试结果:

  **3.2 配合@param使用,自定义参数名**

  Mapper类文件:
  List<User> selectByMap2(@Param("mapList") Map<String,List<User>> paramMap);

  Mapper.xml文件:
  <select id="selectByMap2" parameterType="java.util.Map" resultType="com.example.demo.dto.User">
    SELECT id,name,note from USER
    where id in
    <foreach collection="mapList.userMap" separator="," open="(" close=")" item="user">
        #{user.id}
    </foreach>
  </select>

测试结果:

posted @   风去影无踪  阅读(2974)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示