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