Mybatis Mybatis-Plus傳入多個(gè)參數(shù)的處理方式
Mybatis Mybatis-Plus傳入多個(gè)參數(shù)處理
在使用Mybatis、Mybatis-Plus開發(fā)的過程中,我們經(jīng)常會(huì)遇到傳入多個(gè)參數(shù)的場(chǎng)景,這時(shí)如果不加處理的話就可能報(bào)錯(cuò),那么,怎么規(guī)避這些問題呢,下面分享下我在項(xiàng)目中的處理:
方案一、
dao層注解處理,也是最常用的一種處理方法,例如:
public boolean updateBean(@Param("id")String id, @Param("code")String code);
XML Mapper 正常接收使用就好(由于多參數(shù)傳入,所以不需要設(shè)置parameterType)
<update id="updateBean"> update tableName set code = #[code] where id = #{id} </update >
方案二、
Map封裝多參數(shù),將要傳遞的參數(shù)封裝進(jìn)map中,然后正常接收使用,例如
public boolean updateBean(HashMap map);
<update id="updateBean" parameterType="java.util.Map"> update tableName set code = #[code] where id = #{id} </update >
其他的方案都是使用比較少或者限制比較多的,就不一一贅述了,這兩種方案應(yīng)該可以滿足我們?nèi)粘i_發(fā)的大部分需求了
Mybatis傳多個(gè)參數(shù)常見解決
最近隨著項(xiàng)目的深入,逐漸的對(duì)數(shù)據(jù)庫的應(yīng)用越來越深入,已經(jīng)開始根據(jù)自身的業(yè)務(wù)寫mapper方法了,然后看到這篇帖子,好的東西要吸收進(jìn)來,原文如下:
據(jù)我目前接觸到的傳多個(gè)參數(shù)的方案有三種。
第一種方案
DAO層的函數(shù)方法
Public User selectUser(String name,String area);
對(duì)應(yīng)的Mapper.xml
<select id="selectUser" resultMap="BaseResultMap"> select * from user_user_t where user_name = #{0} and user_area=#{1} </select>
其中,#{0}代表接收的是dao層中的第一個(gè)參數(shù),#{1}代表dao層中第二參數(shù),更多參數(shù)一致往后加即可。
第二種方案
此方法采用Map傳多參數(shù)
Dao層的函數(shù)方法
Public User selectUser(Map paramMap);
應(yīng)的Mapper.xml
<select id=" selectUser" resultMap="BaseResultMap"> select * from user_user_t where user_name = #{userName,jdbcType=VARCHAR} and user_area=#{userArea,jdbcType=VARCHAR} </select>
Service層調(diào)用
Private User xxxSelectUser(){ Map paramMap=new hashMap(); paramMap.put(“userName”,”對(duì)應(yīng)具體的參數(shù)值”); paramMap.put(“userArea”,”對(duì)應(yīng)具體的參數(shù)值”); User user=xxx. selectUser(paramMap);}
個(gè)人認(rèn)為此方法不夠直觀,見到接口方法不能直接的知道要傳的參數(shù)是什么。
第三種方案
Dao層的函數(shù)方法
Public User selectUser(@param(“userName”)String name,@param(“userArea”)String area);
對(duì)應(yīng)的Mapper.xml
<select id=" selectUser" resultMap="BaseResultMap"> select * from user_user_t where user_name = #{userName,jdbcType=VARCHAR} and user_area=#{userArea,jdbcType=VARCHAR} </select>
個(gè)人覺得這種方法比較好,能讓開發(fā)者看到dao層方法就知道該傳什么樣的參數(shù),比較直觀,個(gè)人推薦用此種方案。
ps:今天在網(wǎng)上看到第三種方案其實(shí)還是傳個(gè)map進(jìn)去,只不過不用像方案二一樣顯式的指定,而是通過param注解就可以了。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
啟用springboot security后登錄web頁面需要用戶名和密碼的解決方法
這篇文章主要介紹了啟用springboot security后登錄web頁面需要用戶名和密碼的解決方法,也就是使用默認(rèn)用戶和密碼登錄的操作方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02springboot新建項(xiàng)目pom.xml文件第一行報(bào)錯(cuò)的解決
這篇文章主要介紹了springboot新建項(xiàng)目pom.xml文件第一行報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01javaweb servlet中使用請(qǐng)求轉(zhuǎn)發(fā)亂碼的實(shí)現(xiàn)
下面小編就為大家?guī)硪黄猨avaweb servlet中使用請(qǐng)求轉(zhuǎn)發(fā)亂碼的實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08利用MyBatis實(shí)現(xiàn)條件查詢的方法匯總
這篇文章主要給大家介紹了關(guān)于利用MyBatis實(shí)現(xiàn)條件查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用MyBatis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08java根據(jù)當(dāng)前時(shí)間獲取yyyy-MM-dd?HH:mm:ss標(biāo)準(zhǔn)格式的時(shí)間代碼示例
在Java中可以使用java.time包中的LocalDateTime類和DateTimeFormatter類來獲取并格式化當(dāng)前時(shí)間為yyyy-MM-dd?HH:mm:ss的格式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-10-10