Java中MyBatis傳入?yún)?shù)parameterType問題
parameterType:MyBatis的傳入?yún)?shù)
參數(shù)類型主要分為兩種
(1)基本數(shù)據(jù)類型:int,string,long,Date
(2)復雜數(shù)據(jù)類型:類和Map
獲取參數(shù)中的值
(1)基本數(shù)據(jù)類型:#{參數(shù)} 獲取參數(shù)中的值
(2)復雜數(shù)據(jù)類型:#{屬性名} ,map中則是#{key}
首先說說單參數(shù)基本數(shù)據(jù)類型,如:String,Long
一、單參數(shù)
//根據(jù)name查詢
public List<XXBean> getXXBeanList(String name); ?
?
<select id="getXXBeanList" parameterType="java.lang.String" resultType="XXBean">
select * from User u where u.name = #{name} ?
</select> ?
?
?
//根據(jù)主鍵id查詢
public List<XXBean> getXXBeanList(Long beanId);
?
<select id="getXXBeanList" parameterType="java.lang.String" resultType="XXBean">
select * from User u where u.userId = #{beanId} ?
</select>其中方法名和ID一致,#{}中的參數(shù)名與方法中的參數(shù)名一致, 上面采用的是XXXBean,是采用的短名字,
select 后的字段列表要和bean中的屬性名一致, 如果不一致的可以用 as 別名 來補充
二、多參數(shù)
1、索引 #{index}
public List<XXBean> getXXBeanList(String beanId, String name); ?
?
<select id="getXXBeanList" resultType="XXBean">
select * from user u where u.userId = #{0} and name = #{1} ?
</select> ?由于是多參數(shù),不能使用parameterType, 改用#{index}是第幾個就用第幾個的索引,索引從0開始
#{0}代表接收的是dao層中的第一個參數(shù),#{1}代表dao層中第二參數(shù),更多參數(shù)一致往后加即可
2、Map封裝多參數(shù)
? ? ? ? Map<String, Object> hashmap = new HashMap<String, Object>();
? ? ? ? params.put("userId", userId);
? ? ? ? params.put("userName", userName);
?
public List<XXBean> getXXBeanList(HashMap <String, Object> hashmap); ?
?
<select id="getXXBeanList" parameterType="hashmap" resultType="XXBean">
select * from user u where u.userId=#{userId} name = #{userName} ?
</select> ?其中hashmap是mybatis自己配置好的直接使用就行。map中key的名字是那個就在#{}使用那個
3、List封裝in
public List<XXBean> getXXBeanList(List<String> list); ?
?
<select id="getXXBeanList" resultType="XXBean">
select * from user where userId in
<foreach item="userId" collection="array" open="(" separator="," close=")">
? ? ? ? ?#{userId}
? ?</foreach>
</select> ??foreach 最后的效果是select 字段... from XX where id in ('1','2','3','4')
4、注解方式
public User getUser(@Param("userId")Long userId, @Param("name")String name);Mapper.xml配置:
<select id="getUser" resultMap="com.xxx.xxx.User">
? ? ? ?SELECT * FROM user u?
where u.userId=#{userId} and u.name=#{name}
</select>5、多類型參數(shù)
selectList()只能傳遞一個參數(shù),但實際所需參數(shù)既要包含String類型,又要包含List類型時的處理方法;將參數(shù)放入Map,再取出Map中的List遍歷
List<String> list = new ArrayList<String>();
Map<String, Object> map2 = new HashMap<String, Object>();
?
list.add("1");
list.add("2");
map2.put("list", list);?
?
map2.put("roleCode", "0101");mapper.xml
<select id="getUser" parameterType="java.util.Map" resultMap="User">
select u,userId, u.name, u.code?
? ?from user u
? ?left join role r on r.role_userId = u.userId
? ?WHERE r.code = #{roleCode}?
? ?and r.roleId not in?
? ?<foreach item="roleId" collection="array" open="(" separator="," close=")">
? ? ? ? ?#{roleId}
? ?</foreach>
?</select>總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot配置Spring?Security的實現(xiàn)示例
本文主要介紹了SpringBoot配置Spring?Security的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-10-10
Java?CopyOnWriteArrayList源碼超詳細分析
為了將讀取的性能發(fā)揮到極致,jdk中提供了CopyOnWriteArrayList類,下面這篇文章主要給大家介紹了關(guān)于java中CopyOnWriteArrayList源碼解析的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-11-11

