最近在做一個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:熟能生巧;