1. 程式人生 > >Mybatis使用IN語句查詢

Mybatis使用IN語句查詢

 

一、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>