datatable数据插入mysql_DataTable批量插入数据库

本文通过比较使用SQLCommand ExecuteNonQuery、SqlDataAdapter Update和SqlBulkCopy三种方法,插入20000条记录到DataTable的时间,展示了SqlBulkCopy在数据批量插入MySQL时的显著优势,仅需0.3276秒,而SqlDataAdapter Update和SQLCommand ExecuteNonQuery分别耗时22.8938秒和29.7336秒。
摘要由CSDN通过智能技术生成

最近在将excel中的文件导入到数据库中,用程序进行编写,由于数据量较大所以速度很慢,后来采用了SqlBulkCopy类,解决了速度的问题,我就insert语句,sqldataadapter.update(dataset,tablename);sqlbulkcopy.WriteToServer(datatable);三个方法的性能进行比较:

1、生成测试的datatable表,表结构如下:

UniqueID(主键,自动增长) | CompanyName | CompanyCode | Address | Owner | Memo

共6个字段。

SqlConnection sqlconnection = new SqlConnection(connectionString);SqlDataAdapter sqldataadapter = new SqlDataAdapter("select * from Table_1 where 1=2", sqlconnection);DataSet dataset = new DataSet();sqldataadapter.Fill(dataset, "Table_1");DataTable datatable = dataset.Tables[0];//生成20000条记录

for (int i = 0; i < 20000; i++){         DataRow datarow = datatable.NewRow();         datarow["CompanyName"] = "companyname"+string.Format("{0:0000}",i);         datarow["CompanyCode"] = 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值