【MyBatis框架】mapper配置檔案-foreach標籤
阿新 • • 發佈:2019-01-06
foreach標籤
下面介紹一下一個mapper配置檔案中的foreach標籤(注意,要跟著前面的總結來看,這裡使用的例子是結合前面的工程寫的,大部分程式碼沒有再贅述)
foreach的作用是向sql傳遞陣列或List,mybatis使用foreach解析
1.1需求
在使用者查詢列表和查詢總數的statement中增加多個id輸入查詢。
sql語句如下:
兩種方法:
SELECT * FROM USER WHERE id=1 OR id=3 OR id=5
SELECT * FROM USER WHERE id IN(1,3,5)
1.2在輸入引數型別中新增List<Integer> ids傳入多個id
public class UserQueryVo {
//傳入多個id
private List<Integer> ids;
public List<Integer> getIds() {
return ids;
}
public void setIds(List<Integer> ids) {
this.ids = ids;
}
......
}
1.3修改mapper.xml
WHERE id=1 OR id=3 OR id=5
在查詢條件中,查詢條件定義成一個sql片段,需要修改sql片段。
1.4測試程式碼
測試結果:
1:張三
3:劉莉莉
5:劉三姐
日誌輸出:
可以看到,sql語句select * from user WHERE ( id=? OR id=? OR id=? ) 通過foreach輸出成功
1.5另外一個sql的實現:
下面介紹一下一個mapper配置檔案中的foreach標籤(注意,要跟著前面的總結來看,這裡使用的例子是結合前面的工程寫的,大部分程式碼沒有再贅述)
foreach的作用是向sql傳遞陣列或List,mybatis使用foreach解析
1.1需求
在使用者查詢列表和查詢總數的statement中增加多個id輸入查詢。
sql語句如下:
兩種方法:
SELECT * FROM USER WHERE id=1 OR id=3 OR id=5
SELECT * FROM USER WHERE id IN(1,3,5)
1.2在輸入引數型別中新增List<Integer> ids傳入多個id
public class UserQueryVo {
//傳入多個id
private List<Integer> ids;
public List<Integer> getIds() {
return ids;
}
public void setIds(List<Integer> ids) {
this.ids = ids;
}
......
}
1.3修改mapper.xml
WHERE id=1 OR id=3 OR id=5
在查詢條件中,查詢條件定義成一個sql片段,需要修改sql片段。
-
<prename="code"class="html"><!-- 定義sql片段
- id:sql片段的唯一標識
- 在sql片段中不要加入where
- 經驗:一般我們定義sql片段是為了可重用性,是基於單表來定義sql片段,
- 這樣的話這個sql片段可重用性才高-->
- <sqlid="query_user_where">
- <iftest="ids!=null">
- <!-- 使用foreach遍歷傳入ids
- collection指定輸入物件中集合屬性
- item每次遍歷生成的物件名
- open開始遍歷時要拼接的串
-
close開始遍歷時要拼接的串
- separator遍歷的兩個物件中間需要拼接的串
- -->
- <!-- 使用實現下邊的sql拼接
- WHERE (id=1 OR id=3 OR id=5)-->
- <foreachcollection="ids"item="user_id"open="AND ("close=")"separator="OR">
- <!-- 每次遍歷要拼接的串 -->
- id=#{user_id}
- </foreach>
- </if>
- </sql>
- <!-- 使用者資訊綜合查詢 -->
- <selectid="findUserList"parameterType="cn.edu.hpu.mybatis.PO.UserQueryVo"
- resultType="cn.edu.hpu.mybatis.PO.UserCustom">
- select * from user
- <!-- where標籤可以自動去掉第一個and -->
- <where>
- <!-- 應用sql片段的id,如果refid指定的id不再本mapper檔案中,需要前邊加namespace -->
- <includerefid="query_user_where"></include>
- <!-- 在這裡還可能要引用其他的sql片段 -->
- </where>
- </select>
- //使用者管理的Dao介面
- publicinterface UserMapper {
- //使用者資訊綜合查詢
- public List<UserCustom> findUserList(UserQueryVo userQueryVo) throws Exception;
- ......
- }
1.4測試程式碼
- //使用者資訊綜合查詢
- @Test
- publicvoid testFindUserList() throws Exception{
- SqlSession sqlSession=sqlSessionFactory.openSession();
- //建立UserMapper代理物件
- UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
- //建立包裝物件,設定查詢條件
- UserQueryVo userQueryVo=new UserQueryVo();
- //傳入多個Id
- List<Integer> ids=new ArrayList<Integer>();
- ids.add(1);
- ids.add(3);
- ids.add(5);
- //將ids通過userQueryVo傳入statement中
- userQueryVo.setIds(ids);
- //呼叫userMapper的方法
- List<UserCustom> users=userMapper.findUserList(userQueryVo);
- for (int i = 0; i < users.size(); i++) {
- UserCustom user=(UserCustom)users.get(i);
- System.out.println(user.getId()+":"+user.getUsername());
- }
- }
測試結果:
1:張三
3:劉莉莉
5:劉三姐
日誌輸出:
- DEBUG [main] - Opening JDBC Connection
- DEBUG [main] - Created connection 6867819.
- DEBUG [main] - Setting autocommit to false on JDBC Connection [[email protected]]
- DEBUG [main] - ==> Preparing: select * from user WHERE ( id=? OR id=? OR id=? )
- DEBUG [main] - ==> Parameters: 1(Integer), 3(Integer), 5(Integer)
- DEBUG [main] - <== Total: 3
可以看到,sql語句select * from user WHERE ( id=? OR id=? OR id=? ) 通過foreach輸出成功
1.5另外一個sql的實現:
- <!-- 使用實現下邊的sql拼接
- AND ID IN(1,3,5)-->
- <foreachcollection="ids"item="user_id"open="AND ID IN("close=")"separator=",">
- <!-- 每次遍歷要拼接的串 -->
- #{user_id}
- </foreach>