OracleBulkCopy 批量插入oracle数据库的方法
来源:互联网 发布:方正幼圆字体下载 mac 编辑:程序博客网 时间:2024/05/19 07:25
只有安装了Oracle 11G客户端的机器上才可以用,要用到ODP.NET组件中的oracleDataAccess.DLL,命名空间引用为Oracle.DataAccess.Client;
#region 批量插入数据 /// <summary> /// 批量插入数据 /// </summary> /// <param name="dt">要插入的数据</param> /// <param name="targetTable">数据库中的表</param> public static void BulkToDB(DataTable dt, string targetTable) { OracleConnection conn = new OracleConnection(connOrcleString); OracleBulkCopy bulkCopy = new OracleBulkCopy(connOrcleString, OracleBulkCopyOptions.UseInternalTransaction); //用其它源的数据有效批量加载Oracle表中 //conn.BeginTransaction(); //OracleBulkCopy bulkCopy = new OracleBulkCopy(connOrcleString, OracleBulkCopyOptions.Default); bulkCopy.BatchSize = 100000; bulkCopy.BulkCopyTimeout = 260; bulkCopy.DestinationTableName = targetTable; //服务器上目标表的名称 bulkCopy.BatchSize = dt.Rows.Count; //每一批次中的行数 try { conn.Open(); if (dt != null && dt.Rows.Count != 0) bulkCopy.WriteToServer(dt); //将提供的数据源中的所有行复制到目标表中 } catch (Exception ex) { throw ex; } finally { conn.Close(); if (bulkCopy != null) bulkCopy.Close(); } } #endregion --------------------------------------------------------------------------------------------------第二种方法: public static void AddDBSqlBulkCopy() { DataTable dt = new DataTable(); DataColumn dcname = new DataColumn("Name",typeof(System.String)); dt.Columns.Add(dcname); for (int i = 0; i < 10; i++) { DataRow row = dt.NewRow(); row["Name"] ="Name_" + i.ToString(); dt.Rows.Add(row); } DataSet ds = new DataSet(); ds.Tables.Add(dt); SqlConnection conn = new SqlConnection(connectionString); conn.Open(); //声明SqlBulkCopy ,using释放非托管资源 using (SqlBulkCopy sqlBC = new SqlBulkCopy(conn)) { //一次批量的插入的数据量 sqlBC.BatchSize = 1000; //超时之前操作完成所允许的秒数,如果超时则事务不会提交 ,数据将回滚,所有已复制的行都会从目标表中移除 sqlBC.BulkCopyTimeout = 60; //設定NotifyAfter 属性,以便在每插入10000 条数据时,呼叫相应事件。 sqlBC.NotifyAfter = 10000; sqlBC.SqlRowsCopied += newSqlRowsCopiedEventHandler(sqlBC_SqlRowsCopied); //设置要批量写入的表 sqlBC.DestinationTableName ="dbo.Name"; //自定义的datatable和数据库的字段进行对应 sqlBC.ColumnMappings.Add("Name", "userName"); // sqlBC.ColumnMappings.Add("Name",1); //批量写入 sqlBC.WriteToServer(dt); } conn.Dispose(); } static void sqlBC_SqlRowsCopied(object sender, SqlRowsCopiedEventArgs e) { }
0 0
- OracleBulkCopy 批量插入oracle数据库的方法
- C# OracleBulkCopy 批量插入oracle数据库的方法
- OracleBulkCopy批量插入数据
- oracle的oraclebulkcopy的使用
- 批量插入oracle数据库
- oracle批量插入数据的方法1
- Mybatis Oracle 批量插入数据的方法
- 批量插入数据库的小方法
- 数据库中批量插入数据的方法
- 【物流系统】——C#Oracle批量导入(二)OracleBulkCopy
- mybatis批量插入oracle数据库
- mybatis批量插入oracle数据库
- Mybatis批量插入Oracle数据库
- oracle的批量插入
- 点评 ibatis+oracle 批量插入的三种方法.
- 点评 ibatis+oracle 批量插入的三种方法
- SQLite数据库中批量插入数据的方法详解
- C# .net 批量插入数据库的两种方法
- Struts2中的struts.xml注释
- 100个常用的 PHP 类库、资源和技巧小结
- 前端模块化工具require.js的使用
- 简单链表的实现
- IOS 图形验证码的封装
- OracleBulkCopy 批量插入oracle数据库的方法
- varchar(10)和char(10)的区别?存入abc字符串
- 机器学习资料
- 2014年黑马第九期JAVAEE+hadoop大数据 全套下载
- unity scene 无缝切换(缓存)
- Sphinx参考手册(八)
- angularjs项目目录
- python学习作业D1
- 怎么解决访问所有HTTPS网站显示连接不安全