MyBatis一括挿入(Oracleデータベース)
1283 ワード
転載元:http://blog.csdn.net/yuguiyang1990/article/details/8764043
インターネットから関連資料を調べて、Oracleの大量挿入の方法を整理しました。
インターネットから関連資料を調べて、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>
第二の方法は、より速く使うことです。