码迷,mamicode.com
首页 > 数据库 > 详细

.Net批量插入数据到SQLServer数据库,SqlBulkCopy类批量插入大数据到数据库

时间:2016-11-09 10:59:28      阅读:232      评论:0      收藏:0      [点我收藏+]

标签:nbsp   批量插入   new   catch   public   tab   存储   ram   数据   

批量的的数据导入数据库中,尽量少的访问数据库,高性能的对数据库进行存储。

采用SqlBulkCopy来处理存储数据。SqlBulkCopy存储大批量的数据非常的高效,将内存中的数据表直接的一次性的存储到数据库中,而不需要一次一次的向数据库Insert数据。

经过几次实验,百万级别的数据表,也只需几秒时间内就可以完全的存入数据库中,其速度,比传统的Insert into方法不止快很多倍。

下面看代码:

        /// <summary>
        /// 批量插入数据
        /// </summary>
        /// <param name="connectionString">连接数据库字符串</param>
        /// <param name="tableName">表名称</param>
        /// <param name="dt">需要批量插入数据库DataTable数据源</param>
        /// <param name="bulkCopyTimeout">连接数据库的溢出时间</param>
        /// <returns></returns>
        public static bool SqlBulkCopyByDatatable(string connectionString, string tableName, DataTable dt, int bulkCopyTimeout = 120)
        {
            try
            {
                using (SqlBulkCopy sqlbulkCopy = new SqlBulkCopy(connectionString, SqlBulkCopyOptions.UseInternalTransaction))
                {
                    sqlbulkCopy.DestinationTableName = tableName;
                    sqlbulkCopy.BulkCopyTimeout = bulkCopyTimeout;
                    for (int i = 0; i < dt.Columns.Count; i++)
                    {
                        sqlbulkCopy.ColumnMappings.Add(dt.Columns[i].ColumnName, dt.Columns[i].ColumnName);
                    }
                    sqlbulkCopy.WriteToServer(dt);
                    sqlbulkCopy.Close();//关闭连接  
                    return true;
                }
            }
            catch (System.Exception ex)
            {
                throw ex;
            }

        }

        /// <summary>
        /// 批量插入数据
        /// </summary>
        /// <param name="connectionString">连接数据库字符串</param>
        /// <param name="tableName">表名称</param>
        /// <param name="dt">需要批量插入数据库DataTable数据源</param>
        /// <param name="batchSize">一次批量插入多少条数据</param>
        /// <param name="bulkCopyTimeout">连接数据库的溢出时间</param>
        /// <returns></returns>
        public static bool SqlBulkCopyByDatatable(string connectionString, string tableName, DataTable dt, int batchSize,int bulkCopyTimeout=120)
        {
            try
            {
                using (SqlBulkCopy sqlbulkCopy = new SqlBulkCopy(connectionString, SqlBulkCopyOptions.UseInternalTransaction))
                {
                    sqlbulkCopy.BatchSize = batchSize;
                    sqlbulkCopy.DestinationTableName = tableName;
                    sqlbulkCopy.BulkCopyTimeout = bulkCopyTimeout;
                    for (int i = 0; i < dt.Columns.Count; i++)
                    {
                        sqlbulkCopy.ColumnMappings.Add(dt.Columns[i].ColumnName, dt.Columns[i].ColumnName);
                    }
                    sqlbulkCopy.WriteToServer(dt);
                    sqlbulkCopy.Close();//关闭连接
                    return true;
                }
            }
            catch (System.Exception ex)
            {
                throw ex;
            }

        }

 

.Net批量插入数据到SQLServer数据库,SqlBulkCopy类批量插入大数据到数据库

标签:nbsp   批量插入   new   catch   public   tab   存储   ram   数据   

原文地址:http://www.cnblogs.com/linJie1930906722/p/6045149.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!