在C#中完成海量数据的批量插入和更新


对于海量数据的插入和更新,ADO.NET确实不如JDBC做到好,JDBC有统一的模型来进行批操作.使用起来
非常方便:
 PreparedStatement ps = conn.prepareStatement("insert or update arg1,args2....");
 然后你就可以
 for(int i=0;i<1000000000000000;i++){
  ps.setXXX(realArg);
  .....
  ps.addBatch();
  if(i%500==0){ //假设五百条提交一次
   ps.executeBatch();
   //clear Parame Batch
  }
 }
 ps.executeBatch();
 
这样的操作不仅带来极度大的性能,而且非常方便.按说,ADO.NET中,要实现这样的功能,应该直接在Command接口中
或DataAdapter接口中提供Addbat和CommitBat的API,但ADO.NET的却并没有这样简单地实现,而是要求开发者通过
复杂的变通方法.
 对于大量的插入操作,可以利用一个空的DataTable加入要插入的行,达到一定数量提交后清空该表就行了,
实现起来并不算复杂:

           

 

 

DateTime begin  =  DateTime.Now;
string  connectionString  =  ......;
using (SqlConnection conn  =   new  SqlConnection(connectionString)) {
    conn.Open();
    SqlDataAdapter sd 
= new SqlDataAdapter();
    sd.SelectCommand 
= new SqlCommand("select devid,data_time,data_value from CurrentTest", conn);
    sd.InsertCommand 
= new SqlCommand("insert into CurrentTest (devid,data_time,data_value) "
                    
+ " values (@devid,@data_time,@data_value);", conn);
    sd.InsertCommand.Parameters.Add(
"@devid", SqlDbType.Char, 18"devid");
    sd.InsertCommand.Parameters.Add(
"@data_time", SqlDbType.Char, 19"data_time");
    sd.InsertCommand.Parameters.Add(
"@data_value", SqlDbType.Int, 8"data_value");
    sd.InsertCommand.UpdatedRowSource 
= UpdateRowSource.None;
    sd.UpdateBatchSize 
  • 2
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值