Mybatis使用IN語句查詢
阿新 • • 發佈:2018-12-24
一、Mybatis使用IN語句查詢
寫法一:
在SQL語法中如果我們想使用in的話直接可以像如下一樣使用:
select * from ec_org_person where state in ('1','2', '3' )
但是如果在MyBatis中的使用in的話
<select id="findPersonByLogNameAndEntity" parameterClass="java.util.HashMap" resultClass="java.util.HashMap"> select * from ec_org_person where state in ('1', '2', '3') and logname = #logname# <isNotEmpty prepend="AND" property="entity"> entity = #entity# </isNotEmpty> <isEmpty prepend="AND" property="entity"> entity is null </isEmpty> </select>
寫法二:
MyBatis中提供了foreach語句實現IN查詢,foreach語法如下:
foreach語句中, collection屬性的引數型別可以使:List、陣列、map集合 collection: 必須跟mapper.java中@Param標籤指定的元素名一樣 item: 表示在迭代過程中每一個元素的別名,可以隨便起名,但是必須跟元素中的#{}裡面的名稱一樣。 index:表示在迭代過程中每次迭代到的位置(下標) open:字首, sql語句中集合都必須用小括號()括起來 close:字尾 separator:分隔符,表示迭代時每個元素之間以什麼分隔
正確的寫法有以下幾種寫法:
(一)、selectByIdSet(List idList)
如果引數的型別是List, 則在使用時,collection屬性要必須指定為 list
List<User> selectByIdSet(List idList);
<select id="selectByIdSet" resultMap="BaseResultMap"> SELECT <include refid="Base_Column_List" /> from t_user WHERE id IN <foreach collection="list" item="id" index="index" open="(" close=")" separator=","> #{id} </foreach> </select>
(二)、List<User> selectByIdSet(String[] idList)
如果引數的型別是Array,則在使用時,collection屬性要必須指定為 array
List<User> selectByIdSet(String[] idList);
<select id="selectByIdSet" resultMap="BaseResultMap">
SELECT
<include refid="Base_Column_List" />
from t_user
WHERE id IN
<foreach collection="array" item="id" index="index" open="(" close=")" separator=",">
#{id}
</foreach>
</select>
(三)、引數有多個時
當查詢的引數有多個時,有兩種方式可以實現,一種是使用@Param("xxx")進行引數繫結,另一種可以通過Map來傳引數。
3.1 @Param("xxx")方式
List<User> selectByIdSet(@Param("name")String name, @Param("ids")String[] idList);
<select id="selectByIdSet" resultMap="BaseResultMap">
SELECT
<include refid="Base_Column_List" />
from t_user
WHERE name=#{name,jdbcType=VARCHAR} and id IN
<foreach collection="idList" item="id" index="index"
open="(" close=")" separator=",">
#{id}
</foreach>
</select>
3.2 Map方式
Map<String, Object> params = new HashMap<String, Object>(2);
params.put("name", name);
params.put("idList", ids);
mapper.selectByIdSet(params);
<select id="selectByIdSet" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from t_user where
name = #{name}
and ID in
<foreach item="item" index="index" collection="idList" open="(" separator="," close=")">
#{item}
</foreach>