1. 程式人生 > >數據庫--MyBatis的(insert,update,delete)三種批量操作

數據庫--MyBatis的(insert,update,delete)三種批量操作

tno open let 項目 sep arraylist htm 子句 由於

轉自:http://blog.csdn.net/starywx/article/details/23268465

前段時間由於項目趕期沒顧上開發過程中的性能問題,現對部分代碼進行優化的過程中發現在數據量大的情況下對數據的操作反應似乎有些慢,就想到對數據庫DML操作的時候進行批量操作。說道這裏也想到自己在一次面試的時候別問道過批量操作數據的問題。
現對運用說明記錄如下:
批量插入insert
方法一:
<insert id="insertbatch" parameterType="java.util.List">
  <selectKey keyProperty="id" order="AFTER"
  resultType="int">
  SELECT LAST_INSERT_ID()
  </selectKey>
   INSERT INTO  sourcedoc (
sdate, sweek, 
      roomno, daysched, nightsched, 
      adminsched, vacationsched, programdept, 
      programname 
)values
<foreach collection="list" item="item" index="index" separator=",">
(
#{item.sdate},#{item.sweek},#{item.roomno},
#{item.daysched},#{item.nightsched},#{item.adminsched},
#{item.vacationsched},#{item.programdept},#{item.programname}
        )
</foreach>
</insert>

方法二: <insert id="batchInsert" parameterType="ArrayList"> insert into table1(sdate,sweek,roomno,daysched,nightsched,adminsched,vacationsched,programdept,programname) <foreach collection="list" item="item" index="index" separator="union all"> select #{item.sdate,jdbcType=VARCHAR}, #{item.sweek,jdbcType=VARCHAR}, #{item.roomno,jdbcType=VARCHAR}, #{item.nightsched,jdbcType=VARCHAR}, #{item.adminsched,jdbcType=VARCHAR}, #{item.vacationsched,jdbcType=VARCHAR}, #{item.programdept,jdbcType=VARCHAR},0,0, #{item.programname,jdbcType=VARCHAR} from dual </foreach> </insert> 可以考慮用union all來實現批量插入。 例如: insert into XX_TABLE(XX,XX,XX)select ‘xx‘,‘xx‘,‘xx‘ union all select ‘xx‘,‘xx‘,‘xx‘ union all select ‘xx‘,‘xx‘,‘xx‘ ... 先拼裝好語句再動態傳入insert into XX_TABLE(XX,XX,XX)後面部分
批量刪除(delete) <!-- 通過主鍵集合批量刪除記錄 --> <delete id="batchRemoveUserByPks" parameterType="java.util.List"> DELETE FROM LD_USER WHERE ID in <foreach item="item" index="index" collection="list" open="(" separator="," close=")"> #{item} </foreach> </delete>
批量修改(update) <update id="updateOrders" parameterType="java.util.List"> update orders set state = ‘0‘ where no in <foreach collection="list" item="nos" open="(" separator="," close=")"> #{nos} </foreach> </update>
MyBatis中in子句 in 參數 使用方法 1.只有一個參數 參數的類型要聲明為List或Array Sql配置如下: <select id="selectProduct" resultMap="Map"> SELECT * FROM PRODUCT WHERE PRODUCTNO IN <foreach item="productNo" index="index" collection="參數的類型List或array"> #{productNo} </foreach> </select>
2.多個參數 首先要將多個參數寫入同一個map,將map作為一個參數傳入mapper Sql配置如下: <select id="selectSoucedoc" resultMap="Map"> SELECT * FROM PRODUCT WHERE PRODUCTNO IN <foreach item="id" index="index" collection="map中集合參數的名稱"> #{id} </foreach> </select> 批量數據操作的體會 MyBatis的前身就是著名的Ibatis,不知何故脫離了Apache改名為MyBatis。 MyBatis所說是輕量級的ORM框架,在網上看過一個測試報告,感覺相比於Hibernate來說,優勢並不明顯。 下面說一下比較有趣的現象,根據MyBatis的官方文檔,在獲得sqlSession時,它有為批量更新而專門準備的: session = sessionFactory.openSession();//用於普通update session = sessionFactory.openSession(ExecutorType.BATCH, true);//用於批量update 一般來說,對MYSQL數據庫批量操作時速度取決於,是為每一個處理分別建立一個連接,還是為這一批處理一共建立一個連接。按MyBatis的手冊說明,選擇ExecutorType.BATCH意味著,獲得的sqlSession會批量執行所有更新語句。不過我測試了一下,批量插入1000條數據,發覺ExecutorType.BATCH方式的效率居然比普通的方式差很多。我測試用的Mapper中的insert配置如下,再用for循環插入1000條記錄: <insert id="insert" parameterType="sdc.mybatis.test.Student"> insert into student (id, name, sex, address, telephone, t_id ) values (#{id,jdbcType=INTEGER}, #{name,jdbcType=VARCHAR}, #{sex,jdbcType=VARCHAR}, #{address,jdbcType=VARCHAR}, #{telephone,jdbcType=VARCHAR}, #{tId,jdbcType=INTEGER} ) </insert> 關於數據庫批量插入時sql語句級的優化,我特意測試了兩種方式,在StudentMapper中配置了兩種insert模式。第一種對應insert value1,insert value2,,,,;第二種對應insert values (value1, value2,....)。發現後者果然比前者快很多啊。下面是兩種insert模式,及測試結果對應圖: <!-- 批量 ,傳入一個長度為1000的list --> insert into student ( <include refid="Base_Column_List"/> ) values <foreach collection="list" item="item" index="index" separator=","> (null,#{item.name},#{item.sex},#{item.address},#{item.telephone},#{item.tId}) </foreach> </insert> <!-- 在外部for循環調用一千次 --> <insert id="insert" parameterType="sdc.mybatis.test.Student"> insert into student (id, name, sex, address, telephone, t_id ) values (#{id,jdbcType=INTEGER}, #{name,jdbcType=VARCHAR}, #{sex,jdbcType=VARCHAR}, #{address,jdbcType=VARCHAR}, #{telephone,jdbcType=VARCHAR}, #{tId,jdbcType=INTEGER} ) </insert>

  

數據庫--MyBatis的(insert,update,delete)三種批量操作