45IT.COM- 电脑学习从此开始!
DIY硬件教程攒机经验装机配置
设计Photoshop网页设计特效
系统注册表DOS系统命令其它
存储主板显卡外设键鼠内存
维修显卡CPU内存打印机
WinXPVistaWin7unix/linux
CPU光驱电源/散热显示器其它
修技主板硬盘键鼠显示器光驱
办公ExcelWordPowerPointWPS
编程数据库CSS脚本PHP
网络局域网QQ服务器
软件网络系统图像安全
页面导航: 首页 > 设计学院 > 网络编程 > 数据库 >

iBATIS批量插入数据到Oracle数据库

电脑软硬件应用网 45IT.COM 时间:2013-07-24 14:28 作者:佚名

在iBATIS框架中使用回调接口,同样也可以实现数据的批量操作,减少对数据库的访问次数,提高性能。下面是一个使用iBATIS框架向Oracle数据库批量插入数据的例子:

批量插入数据方法实现:

 代码如下  

/**
 * ibatis批量插入数据
 * @param recordList
 */
public void insertRecordByList(final List<Record> recordList) {
 this.getSqlMapClientTemplate().execute(new SqlMapClientCallback() {
  public Object doInSqlMapClient(SqlMapExecutor executor)
    throws SQLException {
   executor.startBatch();
   // 每次提交最大条数
   final int batchSize = 200;
   int count = 0;
   for (Record record : recordList) {
    executor.insert("Record.insertRecord", record);
    // 每200条数据提交一次
    if (++count % batchSize == 0) {
     executor.executeBatch();
    }
   }
   // 提交剩余的数据
   executor.executeBatch();
   return null;
  }
 });
}

对应的sqlMap:

 代码如下  

<sqlMap namespace="Record">
 <typeAlias alias="record" type="me.gogogogo.domain.Record" />

 <insert id="insertRecord"  parameterClass="record">
  insert into record
   (id,
   record,
   insetDate)
  values
   (sequence_record.nextval,
   #record#,
   sysdate)
 </insert>
</sqlMap>

顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
无法在这个位置找到: baidushare.htm
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
验证码:点击我更换图片
推荐知识