MyBatis3傳遞多個(gè)參數(shù)(Multiple Parameters)
傳遞多個(gè)參數(shù)一般用在查詢上,比如多個(gè)條件組成的查詢,有以下方式去實(shí)現(xiàn):
版本信息:
MyBatis:3.4.4
1、自帶方法
<select id="getUserArticlesByLimit" resultMap="resultUserArticleList"> select user.id,user.userName,user.userAddress,article.id as aid,article.title,article.content from user,article where user.id=article.userid and user.id=#{arg0} limit #{arg1},#{arg2} </select>
public List<Article> getUserArticlesByLimit(int id,int start,int limit); List<Article> articles=userMapper.getUserArticlesByLimit(1,0,2);
說明,arg0...也可以寫成param0...
2、直接傳遞對(duì)象
<select id="dynamicIfTest" parameterType="Article" resultType="Article"> select * from article where 1 = 1 <if test="title != null"> and title = #{title} </if> <if test="content != null"> and content = #{content} </if> limit 1 </select>
public Article dynamicIfTest(Article article); Article inArticle = new Article(); inArticle.setTitle("test_title"); Article outArticle = userOperation.dynamicIfTest(inArticle);
3、使用@Praam標(biāo)注
<select id="dynamicChooseTest" resultType="Article"> select * from article where 1 = 1 <choose> <when test="title != null"> and title = #{title} </when> <when test="content != null"> and content = #{content} </when> <otherwise> and tile = "test_title" </otherwise> </choose> </select>
public Article dynamicChooseTest( @Param("title") String title, @Param("content") String content); Article outArticle2 = userOperation.dynamicChooseTest("test_title",null);
說明:這種方法同樣可以用在一個(gè)參數(shù)的時(shí)候。
4、使用HashMap
<select id="getArticleBeanList" resultType="ArticleBean"> select * from article where id = #{id} and name = #[code] </select>
說明:parameterType="hashmap"可以不用寫。
public List<ArticleBean> getArticleBeanList(HashMap map);
HashMap<String, Object> map = new HashMap<String, Object>(); map.put("id", 1); map.put("code", "123"); List<Article> articless3 = userOperation.getArticleBeanList(map);
特殊的HashMap示例,用在foreach節(jié)點(diǎn):
<select id="dynamicForeach3Test" resultType="Article"> select * from article where title like "%"#{title}"%" and id in <foreach collection="ids" index="index" item="item" open="(" separator="," close=")"> #{item} </foreach> </select>
public List<Article> dynamicForeach3Test(Map<String, Object> params);
HashMap<String, Object> map = new HashMap<String, Object>(); map.put("title", "title"); map.put("ids", new int[]{1,3,6}); List<Article> articless3 = userOperation.dynamicForeach3Test(map);
5、List結(jié)合foreach節(jié)點(diǎn)一起使用
<select id="dynamicForeachTest" resultType="Article"> select * from article where id in <foreach collection="list" index="index" item="item" open="(" separator="," close=")"> #{item} </foreach> </select>
public List<Article> dynamicForeachTest(List<Integer> ids);
List<Integer> ids = new ArrayList<Integer>(); ids.add(1); ids.add(3); ids.add(6); List<Article> articless = userOperation.dynamicForeachTest(ids);
6、數(shù)組結(jié)合foreach節(jié)點(diǎn)一起使用
<select id="dynamicForeach2Test" resultType="Article"> select * from article where id in <foreach collection="array" index="index" item="item" open="(" separator="," close=")"> #{item} </foreach> </select>
public List<Article> dynamicForeach2Test(int[] ids);
int[] ids2 = {1,3,6}; List<Article> articless2 = userOperation.dynamicForeach2Test(ids2);
參考:
http://www.yihaomen.com/article/java/426.htm
到此這篇關(guān)于MyBatis3傳遞多個(gè)參數(shù)(Multiple Parameters)的文章就介紹到這了,更多相關(guān)MyBatis3傳遞多個(gè)參數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 淺談為什么要使用mybatis的@param
- mybatis多個(gè)接口參數(shù)的注解使用方式(@Param)
- MyBatis中傳入?yún)?shù)parameterType類型詳解
- Mybatis中@Param的用法和作用詳解
- 解決Python paramiko 模塊遠(yuǎn)程執(zhí)行ssh 命令 nohup 不生效的問題
- python requests包的request()函數(shù)中的參數(shù)-params和data的區(qū)別介紹
- vue.js this.$router.push獲取不到params參數(shù)問題
- Mybatis使用@param注解四種情況解析
相關(guān)文章
Jdk11使用HttpClient提交Http2請(qǐng)求的實(shí)現(xiàn)方法
這篇文章主要介紹了Jdk11使用HttpClient提交Http2請(qǐng)求的實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08Spring?Security過濾器鏈加載執(zhí)行流程源碼解析
Spring?Boot?對(duì)于?Spring?Security?提供了自動(dòng)化配置方案,可以使用更少的配置來使用?Spring?Security。那么這個(gè)過濾器鏈?zhǔn)窃趺醇虞d和實(shí)現(xiàn)攔截的呢,對(duì)Spring?Security過濾器鏈加載執(zhí)行流程感興趣的朋友一起看看吧2021-12-12劍指Offer之Java算法習(xí)題精講二叉樹的構(gòu)造和遍歷
跟著思路走,之后從簡(jiǎn)單題入手,反復(fù)去看,做過之后可能會(huì)忘記,之后再做一次,記不住就反復(fù)做,反復(fù)尋求思路和規(guī)律,慢慢積累就會(huì)發(fā)現(xiàn)質(zhì)的變化2022-03-03Spring Boot中的 6 種API請(qǐng)求參數(shù)讀取方式示例詳解
使用Spring Boot開發(fā)API的時(shí)候,讀取請(qǐng)求參數(shù)是服務(wù)端編碼中最基本的一項(xiàng)操作,Spring Boot中也提供了多種機(jī)制來滿足不同的API設(shè)計(jì)要求,這篇文章主要介紹了Spring Boot中的 6 種API請(qǐng)求參數(shù)讀取方式示例詳解,需要的朋友可以參考下2024-05-05Java使用EasyExcel模版導(dǎo)出詳細(xì)操作教程
業(yè)務(wù)中經(jīng)常需要按照一個(gè)特定的模板導(dǎo)出特定內(nèi)容,有些單元格還要求特殊的格式,所以下面這篇文章主要給大家介紹了關(guān)于Java使用EasyExcel模版導(dǎo)出的相關(guān)資料,需要的朋友可以參考下2023-10-10java內(nèi)存模型jvm虛擬機(jī)簡(jiǎn)要分析
Java 內(nèi)存模型的主要目的是定義程序中各種變量的訪問規(guī)則, 關(guān)注在虛擬機(jī)中把變量值存儲(chǔ)到內(nèi)存和從內(nèi)存中取出變量值這樣的底層細(xì)節(jié)2021-09-09java多線程關(guān)鍵字final和static詳解
這篇文章主要介紹了java多線程關(guān)鍵字final和static詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01通過圖例了解IDEA引入JQuery實(shí)現(xiàn)步驟
這篇文章主要介紹了IDEA引入JQuery實(shí)現(xiàn)步驟圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09淺談springioc實(shí)例化bean的三個(gè)方法
下面小編就為大家?guī)硪黄獪\談springioc實(shí)例化bean的三個(gè)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就想給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09