1. 程式人生 > >在mybatis中處理集合、迴圈、陣列和in查詢等語句的使用

在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);

}