MyBatis一括挿入(Oracleデータベース)

1283 ワード

転載元:http://blog.csdn.net/yuguiyang1990/article/details/8764043
インターネットから関連資料を調べて、Oracleの大量挿入の方法を整理しました。
<insert id="insertBatch" parameterType="ArrayList" useGeneratedKeys="true">
    	<selectKey keyProperty="deptno" order="BEFORE" resultType="int">
    		SELECT S_FORUM_USERID.NEXTVAL FROM DUAL
    	</selectKey>
    	
    	INSERT INTO DEPT(DEPTNO , DNAME , LOC) SELECT S_FORUM_USERID.NEXTVAL , A.* FROM (
    	<foreach collection="list" item="item" index="index" separator="UNION">
    		SELECT #{item.dname} , #{item.loc} FROM DUAL
    	</foreach>
    	) A
    </insert>
ソース:http://doufuguolyl.iteye.com/blog/1998669
<insert id="batchInsert" parameterType="java.util.List"> 
    insert into DATA (ID, TEXT, STAUTS) 
    <foreach close=")" collection="list" item="item" index="index" open="(" separator="union"> 
    select 
        #{item.id,jdbcType=VARCHAR}, 
        #{item.text,jdbcType=VARCHAR}, 
        #{item.stauts,jdbcType=VARCHAR} 
    from dual 
    </foreach> 
</insert>
第二の方法は、より速く使うことです。