Mybatis 中selete的parameterType問題

最近在做一個Mybatis的項目,由於是接觸不久,雖然看了一下資料,但在實際開發中還是暴露了很多問題,其中最讓我頭疼的就是selete的parameterType問題,網上這類的帖子雖然有但是不全,很多情況下很難找到你想要的答案。
爲此我對這個問題進行了總結,希望對像我這樣的新手有一定的幫助。

(一)單個參數
public List<XXBean> getXXBeanList(String xxCode);

<select id="getXXXBeanList" parameterType="java.lang.String" resultType="XXBean">
select 字段... from XXX where code = #{xxCode} 
</select>

其中方法名和ID一致,#{}中的參數名與方法中的參數名一直, 我這裏採用的是XXXBean是採用的短名字, select 後的字段列表要和bean中的屬性名一致, 如果不一致的可以用 as 來補充。


(二)多參數
public List<XXXBean> getXXXBeanList(String xxId, String xxCode);

<select id="getXXXBeanList" resultType="XXBean">
select 字段... from XXX where id=#{0} code = #{1} 
</select>

由於是多參數那麼就不能使用parameterType, 改用#{index}是第幾個就用第幾個的索引,索引從0開始

(三)Map封裝多參數

public List<XXXBean> getXXXBeanList(HashMap map);

<select id="getXXXBeanList" parameterType="hashmap" resultType="XXBean">
select 字段... from XXX where id=#{xxId} code = #{xxCode} 
</select>

其中hashmap是mybatis自己配置好的直接使用就行。map中key的名字是那個就在#{}使用那個,map如何封裝就不用了我說了吧。

(四)List封裝IN
public List<XXXBean> getXXXBeanList(List<String> list);

<select id="getXXXBeanList" resultType="XXBean">
select 字段... from XXX where id in
<foreach item="item" index="index" collection="list"
open="(" separator="," close=")"> 
#{item} 
</foreach> 
</select>

foreach 最後的效果是select 字段... from XXX where id in ('1','2','3','4')

結束語:

1:知識在於不斷地運用和總結;

2:書讀百遍其義自見;

3:熟能生巧;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章