2 回答

TA貢獻1856條經驗 獲得超5個贊
1. 當查詢的參數只有一個時
findByIds(List<Long> ids)
1.a 如果參數的類型是List, 則在使用時,collection屬性要必須指定為 list
<select id="findByIdsMap" resultMap="BaseResultMap">
Select
<include refid="Base_Column_List" />
from jria where ID in
<foreach item="item" index="index" collection="list"
open="(" separator="," close=")">
#{item}
</foreach>
</select>
findByIds(Long[] ids)
1.b 如果參數的類型是Array,則在使用時,collection屬性要必須指定為 array
<select id="findByIdsMap" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from jria where ID in
<foreach item="item" index="index" collection="array"
open="(" separator="," close=")">
#{item}
</foreach>
</select>
2. 當查詢的參數有多個時,例如 findByIds(String name, Long[] ids)
這種情況需要特別注意,在傳參數時,一定要改用Map方式, 這樣在collection屬性可以指定名稱
下面是一個示例
Map<String, Object> params = new HashMap<String, Object>(2);
params.put("name", name);
params.put("ids", ids);
mapper.findByIdsMap(params);
<select id="findByIdsMap" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from jria where ID in
<foreach item="item" index="index" collection="ids"
open="(" separator="," close=")">
#{item}
</foreach>
</select>
完整的示例如下:
例如有一個查詢功能,Mapper接口文件定義如下方法:
List<Jria> findByIds(Long... ids);
使用 in 查詢的sql拼裝方法如下:
<select id="findbyIds" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from jria where ID in
<foreach item="item" index="index" collection="array"
open="(" separator="," close=")">
#{item}
</foreach>
</select>

TA貢獻1820條經驗 獲得超10個贊
我的也是字符拆成的數組,你這樣:
*Controller類中部分代碼>>>
String[] section = names.getModule().split(",");
System.out.println("查詢條件參數:"+list);
List<EMS_TroubleShootingData> tsList = tsdService.getDataBySections(list);
req.setAttribute("list", tsList);
return "TroubleShootingList";
Dao,Service及其實現類中都使用:(List<String> list);作為參數
最后*Mapper.xml文件中:
- 2 回答
- 0 關注
- 3252 瀏覽
添加回答
舉報