溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Mybatis數(shù)據(jù)批量插入的實現(xiàn)方法

發(fā)布時間:2020-07-30 09:34:43 來源:億速云 閱讀:145 作者:小豬 欄目:開發(fā)技術(shù)

這篇文章主要講解了Mybatis數(shù)據(jù)批量插入的實現(xiàn)方法,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。

1:xml的配置

 <insert id="insertUserBatch">
  insert into user(username, birthday, sex, address)
  VALUES
  <foreach collection="list" item="User" index="index" separator=",">
    (
     #{User.username},
     #{User.birthday},
     #{User.sex},
     #{User.address}
    )
  </foreach>
</insert>

2:測試

@Test
public void insertUserBatch() {
  List<User> users = new ArrayList<User>();

  User user1 = new User();
  user1.setUsername("云澈");
  user1.setSex("男");

  User user2 = new User();
  user2.setUsername("張小凡");
  user2.setSex("男");

  User user3 = new User();
  user3.setUsername("火靈兒");
  user3.setSex("女");

  users.add(user1);
  users.add(user2);
  users.add(user3);


  userMapper.insertUserBatch(users);
  sqlSession.commit();
}

對于foreach標(biāo)簽的解釋參考了網(wǎng)上的資料,具體如下:

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

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

item表示集合中每一個元素進行迭代時的別名,index指定一個名字,用于表示在迭代過程中,每次迭代到的位置,open表示該語句以什么開始,separator表示在每次進行迭代之間以什么符號作為分隔 符,close表示以什么結(jié)束,在使用foreach的時候最關(guān)鍵的也是最容易出錯的就是collection屬性,該屬性是必須指定的,但是在不同情況 下,該屬性的值是不一樣的,主要有一下3種情況:

1.如果傳入的是單參數(shù)且參數(shù)類型是一個List的時候,collection屬性值為list

2.如果傳入的是單參數(shù)且參數(shù)類型是一個array數(shù)組的時候,collection的屬性值為array

3.如果傳入的參數(shù)是多個的時候,我們就需要把它們封裝成一個Map了,當(dāng)然單參數(shù)也可以封裝成map

看完上述內(nèi)容,是不是對Mybatis數(shù)據(jù)批量插入的實現(xiàn)方法有進一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI