av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

MyBatis3傳遞多個參數(Multiple Parameters)

瀏覽:3日期:2023-10-23 15:54:37

傳遞多個參數一般用在查詢上,比如多個條件組成的查詢,有以下方式去實現:

版本信息:

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);

說明,arg0...也可以寫成param0...

2、直接傳遞對象

<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標注

<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);

說明:這種方法同樣可以用在一個參數的時候。

4、使用HashMap

<select 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節點:

<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結合foreach節點一起使用

<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、數組結合foreach節點一起使用

<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

到此這篇關于MyBatis3傳遞多個參數(Multiple Parameters)的文章就介紹到這了,更多相關MyBatis3傳遞多個參數內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 亚洲九九九 | 亚洲最大黄色 | 狠狠躁日日躁夜夜躁2022麻豆 | 黄色一级片网站 | 亚洲天堂免费视频 | 亚洲天堂欧美 | 日韩免费大片 | www.天天干| 久久久天堂国产精品女人 | 欧美一级在线观看 | 密乳av | 亚洲自拍偷拍一区 | 解开岳的丰满奶罩bd | 看av| 黄色激情视频在线观看 | 人人草人人干 | 欧美一级特黄视频 | 国产乱码一区二区 | 亚洲国产二区 | 欧美一级片免费 | 91成人精品一区在线播放 | 精品国产毛片 | av网址在线播放 | av在线免费观看网址 | 欧美 日韩 国产 成人 在线 | 亚洲一级免费视频 | 日韩精品三区 | 久久久www成人免费精品 | 天天爽天天操 | 亚洲 欧美 另类 综合 偷拍 | 一级片大全 | 无遮挡在线观看 | 午夜精品久久久久久久久久久久 | 高清不卡av | 五月婷婷丁香网 | 亚洲国产成人精品女人久久久 | 免费av不卡 | 无遮挡毛片 | 日韩精品在线播放 | 岛国av在线免费观看 | 99热99re6国产在线播放 |