成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

foreach與collection怎么在mybatis中使用-創(chuàng)新互聯(lián)

foreach與collection怎么在mybatis 中使用?針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

十余年的安塞網(wǎng)站建設(shè)經(jīng)驗(yàn),針對設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。網(wǎng)絡(luò)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整安塞建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)公司從事“安塞網(wǎng)站設(shè)計(jì)”,“安塞網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。

foreach的主要用在構(gòu)建in條件中,它可以在SQL語句中進(jìn)行迭代一個(gè)集合。

foreach元素的屬性主要有 item,index,collection,open,separator,close。

    item表示集合中每一個(gè)元素進(jìn)行迭代時(shí)的別名,
    index指 定一個(gè)名字,用于表示在迭代過程中,每次迭代到的位置,
    open表示該語句以什么開始,
    separator表示在每次進(jìn)行迭代之間以什么符號作為分隔 符,
    close表示以什么結(jié)束。

在使用foreach的時(shí)候最關(guān)鍵的也是最容易出錯(cuò)的就是collection屬性,該屬性是必須指定的,但是在不同情況 下,該屬性的值是不一樣的,主要有一下3種情況:

    1. 如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)List的時(shí)候,collection屬性值為list
    2. 如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)array數(shù)組的時(shí)候,collection的屬性值為array
    3. 如果傳入的參數(shù)是多個(gè)的時(shí)候,我們就需要把它們封裝成一個(gè)Map了,當(dāng)然單參數(shù)也可

以封裝成map,實(shí)際上如果你在傳入?yún)?shù)的時(shí)候,在breast里面也是會把它封裝成一個(gè)Map的,map的key就是參數(shù)名,所以這個(gè)時(shí)候collection屬性值就是傳入的List或array對象在自己封裝的map里面的key 下面分別來看看上述三種情況的示例代碼:

1.單參數(shù)List的類型:  

 <select id="dynamicForeachTest" resultType="Blog">
      select * from t_blog where id in
    <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
        #{item}    
    </foreach>  
  </select>

上述collection的值為list,對應(yīng)的Mapper是這樣的

public List dynamicForeachTest(List ids);

測試代碼:

@Test
   public void dynamicForeachTest() {
     SqlSession session = Util.getSqlSessionFactory().openSession();   
     BlogMapper blogMapper = session.getMapper(BlogMapper.class);
      List ids = new ArrayList();
      ids.add(1);
      ids.add(3);
      ids.add(6);
     List blogs = blogMapper.dynamicForeachTest(ids);
     for (Blog blog : blogs)
       System.out.println(blog);
     session.close();
   }

2.單參數(shù)array數(shù)組的類型:

 <select id="dynamicForeach3Test" resultType="Blog">
   select * from t_blog where id in
   <foreach collection="array" index="index" item="item" open="(" separator="," close=")">
     #{item}
   </foreach>
 </select>

上述collection為array,對應(yīng)的Mapper代碼:

public List dynamicForeach3Test(int[] ids);

對應(yīng)的測試代碼:

@Test
 public void dynamicForeach3Test() {
     SqlSession session = Util.getSqlSessionFactory().openSession();
     BlogMapper blogMapper = session.getMapper(BlogMapper.class);
     int[] ids = new int[] {1,3,6,9};
     List blogs = blogMapper.dynamicForeach3Test(ids);
     for (Blog blog : blogs)
     System.out.println(blog);  
     session.close();
 }

3.自己把參數(shù)封裝成Map的類型

 <select id="dynamicForeach4Test" resultType="Blog">
     select * from t_blog where title like "%"#{title}"%" and id in
     <foreach collection="ids" index="index" item="item" open="(" separator="," close=")">
        #{item}
     </foreach>
 </select>

上述collection的值為ids,是傳入的參數(shù)Map的key,對應(yīng)的Mapper代碼:

public List dynamicForeach4Test(Map params);

對應(yīng)測試代碼:

@Test
  public void dynamicForeach4Test() {
    SqlSession session = Util.getSqlSessionFactory().openSession();
     BlogMapper blogMapper = session.getMapper(BlogMapper.class);
     final List ids = new ArrayList();
     ids.add(1);
     ids.add(2);
     ids.add(3);
     ids.add(6);
     ids.add(7);
     ids.add(9);
    Map params = new HashMap();
     params.put("ids", ids);
     params.put("title", "中國");
    List blogs = blogMapper.dynamicForeach4Test(params);
     for (Blog blog : blogs)
       System.out.println(blog);
     session.close();
   }

關(guān)于foreach與collection怎么在mybatis 中使用問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

網(wǎng)站標(biāo)題:foreach與collection怎么在mybatis中使用-創(chuàng)新互聯(lián)
URL標(biāo)題:http://jinyejixie.com/article8/dsihip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、企業(yè)建站云服務(wù)器、網(wǎng)站排名、網(wǎng)站改版、微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
高淳县| 宾阳县| 马边| 崇信县| 日土县| 海伦市| 罗定市| 宁陕县| 台北市| 云南省| 买车| 鸡东县| 东至县| 繁峙县| 高清| 武乡县| 武乡县| 云南省| 五莲县| 阜宁县| 互助| 连江县| 阿拉善左旗| 罗山县| 巴彦县| 玉溪市| 屏边| 丰城市| 修文县| 永靖县| 浙江省| 汉寿县| 大荔县| 博乐市| 海盐县| 两当县| 定州市| 依兰县| 岳西县| 安仁县| 万载县|