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>

測試結果:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM