MyBatis3傳遞多個(gè)參數(shù)(Multiple Parameters)
傳遞多個(gè)參數(shù)一般用在查詢上,比如多個(gè)條件組成的查詢,有以下方式去實(shí)現(xiàn):
版本信息:
MyBatis:3.4.4
1、自帶方法
<select 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);
說(shuō)明,arg0...也可以寫(xiě)成param0...
2、直接傳遞對(duì)象
<select 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 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);
說(shuō)明:這種方法同樣可以用在一個(gè)參數(shù)的時(shí)候。
4、使用HashMap
<select resultType='ArticleBean'>select * from article where id = #{id} and name = #[code] </select>
說(shuō)明:parameterType='hashmap'可以不用寫(xiě)。
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 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 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 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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. mysql like語(yǔ)句問(wèn)題2. Mysql入門(mén)系列:MYSQL創(chuàng)建、刪除和選擇數(shù)據(jù)庫(kù)3. 恢復(fù)誤刪數(shù)據(jù)(SQL Server 2000)--Log Explorer4. 用SQL Server為Web瀏覽器提供圖像(三)(轉(zhuǎn))5. 解決mybatis一對(duì)多關(guān)聯(lián)查詢多條數(shù)據(jù)只顯示一條的問(wèn)題6. Mysql入門(mén)系列:MYSQL服務(wù)器內(nèi)部安全性-安全數(shù)據(jù)目錄訪問(wèn)7. MYSQL技巧:為現(xiàn)有字段添加自增屬性8. MySQL中InnoDB和MyISAM類型的差別9. Windows下在DOS用mysql命令行導(dǎo)入.sql文件10. SQL Server補(bǔ)丁版本的檢查和安裝過(guò)程中常見(jiàn)問(wèn)題
