在mybatis中處理集合、迴圈、陣列和in查詢等語句的使用
在Mybatis的xml配置中使用集合,主要是用到了foreach動態語句。
foreach的引數:
foreach元素的屬性主要有 item,index,collection,open,separator,close。
item表示集合中每一個元素進行迭代時的別名.
index指 定一個名字,用於表示在迭代過程中,每次迭代到的位置.
open表示該語句以什麼開始,separator表示在每次進行迭代之間以什麼符號作為分隔 符.
close表示以什麼結束。
1. Mybatis生成select * from table where id in(1,2,...,n)語句的查詢
我們一般的做法是在方法的引數處指定傳入的引數名稱,在xml中使用的時候,集合的名稱要和方法的Param的名稱一致,這樣便於閱讀和理解,然後是在對應的xml檔案中使用foreach迴圈。
java程式碼如下:
publicabstractList<Model> findByIds(@Param("ids")List<Integer> ids);
對應的xml程式碼如下:
select * from table
<where>
id in <foreach collection="ids" item="item" index="index"
open="(" separator="," close=")">#{item}</foreach></where>
2.Mybatis儲存多條記錄
我們同樣是通過foreach的方法來實現,這裡我們巧妙的利用了sql的語法規則用Mybatis的foreach動態語句來處理。
java程式碼:
publicabstractvoid saves(@Param("tables")List<Model> tables);
xml程式碼:
insert into table(name,addtime) values
<foreach collection="tables" item="item" index="index" separator=",">(#{item.name},#{item.addtime})</foreach>
以上方法Mybatis會幫我們進行sql注入攔截,Mybatis如果採用#{xxx}的形式設定引數,Mybatis會進行sql注入的過濾。如果採用的是${xxx},Mybatis不會進行sql注入過濾,而是直接將參入的內容輸出為sql語句。
判斷集合是否有值
<iftest="list!=null and list.size()>0"></if>
迴圈刪除
迴圈刪除時,要求相應的Mapper方法傳遞的引數是一個集合(如List),在<delete>標籤的引數中設定parameterType="java.util.List",書寫sql語句時,使用<foreach>標籤迴圈,其中collection表示Mapper中傳遞的引數名,item便是迴圈時壓入棧頂的元素,open表示第一次加入的sql字首,separator表示集合中每個元素之間的分隔符,colse表示迴圈結束時為sql語句新增的字尾。具體配置如下:
<delete id="deleteList" parameterType="java.util.List">
DELETE FROM CITY WHERE 1 = 1
<foreach collection="list" item="item" open="AND CITY_NO IN(" separator="," close=")">
#{item.cityNo}
</foreach>
</delete>
2、mybatis中Mapper方法傳遞多個引數物件
如果在Mapper中的方法中傳遞了多個引數物件,可以在service層進行封裝(系統的流程為controller->service->mapper),將多個引數封裝到map中,用key值進行區別,然後在mapper.xml中的配置如下:
<select id="findByPage" resultMap="listCityMap" parameterType="java.util.Map">
SELECT CITY_NO, CITY_NAME, PROVINCE_NO FROM CITY WHERE 1 = 1
<if test="city.cityNo != null and city.cityNo != '' ">
AND CITY_NO = #{city.cityNo}
</if>
<if test="city.cityName != null and city.cityName != ''">
AND CITY_NAME = #{city.cityName}
</if>
<if test="city.provinceNo != null and city.provinceNo != ''">
AND PROVINCE_NO = #{city.provinceNo}
</if>
LIMIT #{page.startRowNum}, #{page.pageSize}
</select>
其中在Mapper.xml的<select>標籤的引數中設定parameterType="java.util.Map",在service方法中,有page和city2個形參,故在service的方法中進行如下處理:
public List<City> findByPage(SimplePage page, City city) {
Map<String, Object> paramMap = new HashMap<String, Object>();
paramMap.put("page", page);
paramMap.put("city", city);
return cityMapper.findByPage(paramMap);
}