Java中MyBatis傳入參數(shù)parameterType問題
parameterType:MyBatis的傳入參數(shù)
參數(shù)類型主要分為兩種
(1)基本數(shù)據類型:int,string,long,Date
(2)復雜數(shù)據類型:類和Map
獲取參數(shù)中的值
(1)基本數(shù)據類型:#{參數(shù)} 獲取參數(shù)中的值
(2)復雜數(shù)據類型:#{屬性名} ,map中則是#{key}
首先說說單參數(shù)基本數(shù)據類型,如:String,Long
一、單參數(shù)
//根據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> ?
?
?
//根據主鍵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>總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Netty分布式從recycler對象回收站獲取對象過程剖析
這篇文章主要為大家介紹了Netty分布式從recycler獲取對象的過程源碼剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03
Java微服務Filter過濾器集成Sentinel實現(xiàn)網關限流過程詳解
這篇文章主要介紹了Java微服務Filter過濾器集成Sentinel實現(xiàn)網關限流過程,首先Sentinel規(guī)則的存儲默認是存儲在內存的,應用重啟之后規(guī)則會丟失。因此我們通過配置中心Nacos保存規(guī)則,然后通過定時拉取Nacos數(shù)據來獲取規(guī)則配置,可以做到動態(tài)實時的刷新規(guī)則2023-02-02
Spring Boot使用profile如何配置不同環(huán)境的配置文件
,springboot支持通過不同的profile來配置不同環(huán)境的配置,下面就大致介紹一下yml配置文件跟properties配置文件怎么使用profile配置不同環(huán)境的配置文件2018-01-01
springboot下ueditor上傳功能的實現(xiàn)及遇到的問題
這篇文章主要介紹了springboot下ueditor上傳功能的實現(xiàn)及遇到的問題,本文分步驟通過實例截圖給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11

