Java中MyBatis傳入?yún)?shù)parameterType問題
parameterType:MyBatis的傳入?yún)?shù)
參數(shù)類型主要分為兩種
(1)基本數(shù)據(jù)類型:int,string,long,Date
(2)復(fù)雜數(shù)據(jù)類型:類和Map
獲取參數(shù)中的值
(1)基本數(shù)據(jù)類型:#{參數(shù)} 獲取參數(shù)中的值
(2)復(fù)雜數(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 別名 來補(bǔ)充
二、多參數(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}是第幾個(gè)就用第幾個(gè)的索引,索引從0開始
#{0}代表接收的是dao層中的第一個(gè)參數(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的名字是那個(gè)就在#{}使用那個(gè)
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()只能傳遞一個(gè)參數(shù),但實(shí)際所需參數(shù)既要包含String類型,又要包含List類型時(shí)的處理方法;將參數(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é)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java圖像處理教程之正片疊底效果的實(shí)現(xiàn)
正片疊底效果是我們平時(shí)在Photoshop中會(huì)見到的一種效果,下面這篇文章主要給大家介紹了關(guān)于利用Java如何實(shí)現(xiàn)正片疊底的效果,分享出來供大家參考學(xué)習(xí),文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),需要的朋友可以參考借鑒,下面來一起看看詳細(xì)的介紹吧。2017-09-09
Netty分布式從recycler對(duì)象回收站獲取對(duì)象過程剖析
這篇文章主要為大家介紹了Netty分布式從recycler獲取對(duì)象的過程源碼剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03
Java微服務(wù)Filter過濾器集成Sentinel實(shí)現(xiàn)網(wǎng)關(guān)限流過程詳解
這篇文章主要介紹了Java微服務(wù)Filter過濾器集成Sentinel實(shí)現(xiàn)網(wǎng)關(guān)限流過程,首先Sentinel規(guī)則的存儲(chǔ)默認(rèn)是存儲(chǔ)在內(nèi)存的,應(yīng)用重啟之后規(guī)則會(huì)丟失。因此我們通過配置中心Nacos保存規(guī)則,然后通過定時(shí)拉取Nacos數(shù)據(jù)來獲取規(guī)則配置,可以做到動(dòng)態(tài)實(shí)時(shí)的刷新規(guī)則2023-02-02
Spring Boot使用profile如何配置不同環(huán)境的配置文件
,springboot支持通過不同的profile來配置不同環(huán)境的配置,下面就大致介紹一下yml配置文件跟properties配置文件怎么使用profile配置不同環(huán)境的配置文件2018-01-01
springboot下ueditor上傳功能的實(shí)現(xiàn)及遇到的問題
這篇文章主要介紹了springboot下ueditor上傳功能的實(shí)現(xiàn)及遇到的問題,本文分步驟通過實(shí)例截圖給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11
SpringBoot全局異常與數(shù)據(jù)校驗(yàn)的方法
這篇文章主要介紹了SpringBoot全局異常與數(shù)據(jù)校驗(yàn)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11
Java的RocketMq水平擴(kuò)展及負(fù)載均衡詳解
這篇文章主要介紹了Java的RocketMq水平擴(kuò)展及負(fù)載均衡詳解,RocketMQ是一個(gè)分布式具有高度可擴(kuò)展性的消息中間件,本文旨在探索在broker端,生產(chǎn)端,以及消費(fèi)端是如何做到橫向擴(kuò)展以及負(fù)載均衡的,需要的朋友可以參考下2024-01-01

