Mybatis動(dòng)態(tài)SQL foreach標(biāo)簽用法實(shí)例
需求:傳入多個(gè) id 查詢用戶信息,用下邊兩個(gè) sql 實(shí)現(xiàn):
SELECT * FROM USERS WHERE username LIKE ’%張%’ AND (id =10 OR id =89 OR id=16)
SELECT * FROM USERS WHERE username LIKE ’%張%’ AND id IN (10,89,16)
這樣我們在進(jìn)行范圍查詢時(shí),就要將一個(gè)集合中的值,作為參數(shù)動(dòng)態(tài)添加進(jìn)來。
這樣我們將如何進(jìn)行參數(shù)的傳遞?
1、實(shí)體類
public class QueryVo implements Serializable { private List<Integer> ids; public List<Integer> getIds() {return ids; } public void setIds(List<Integer> ids) {this.ids = ids; } }
2、持久層接口
/*** 根據(jù) id 集合查詢用戶* @param vo* @return*/List<User> findInIds(QueryVo vo);
3、映射文件
<!-- 查詢所有用戶在 id 的集合之中 --><select resultType='user' parameterType='queryvo'> <!-- select * from user where id in (1,2,3,4,5); -->select * from user <where> <if test='ids != null and ids.size() > 0'> <foreach collection='ids' open='id in ( ' close=')' item='uid' separator=','>#{uid} </foreach></if> </where></select>
SQL 語句:
select 字段 from user where id in (?)
foreach標(biāo)簽用于遍歷集合,它的屬性
collection:代表要遍歷的集合元素,注意編寫時(shí)不要寫#{} open:代表語句的開始部分 close:代表結(jié)束部分 item:代表遍歷集合的每個(gè)元素,生成的變量名 sperator:代表分隔符以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 數(shù)據(jù)庫相關(guān)的幾個(gè)技能:ACCESS轉(zhuǎn)SQL2. mysql的like模式3. Mysql入門系列:對MYSQL查詢中有疑問的數(shù)據(jù)進(jìn)行編碼4. Mysql入門系列:建立MYSQL客戶機(jī)程序的一般過程5. 詳解MySQL中的數(shù)據(jù)類型和schema優(yōu)化6. 使用DB2look重新創(chuàng)建優(yōu)化器訪問計(jì)劃(4)8. 教你快速確定SQL Server欄中的最大值9. Sql Server2005學(xué)習(xí)日記(01)10. 盤點(diǎn)SqlServer 分頁方式和拉姆達(dá)表達(dá)式分頁
