using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Web;
 using System.Diagnostics;
 using System.Data;
 using System.Data.SqlClient;
 using System.Configuration;
 using Fx678Member.Framework.Exceptions;

 namespace MeiYuanJinYe.Admin.HttpHandler
 {
     /// <summary>
     /// CreateAccount 的摘要说明
     /// </summary>
     public class CreateAccount : IHttpHandler
     {

         public void ProcessRequest(HttpContext context)
         {
             context.Response.ContentType = "text/plain";
             Guid classRoomId = Guid.Parse(context.Request["ClassRoomId"]);
             int Count = int.Parse(context.Request["Count"]);
             DataTable dt = GetTableSchema();
             Random ran = new Random();
             ; i < Count; i++)//循环往DataTable中赋值
             {
                 DataRow r = dt.NewRow();
                 r[] = ran.Next(, );
                 r[] = ran.Next(, );
                 r[] = classRoomId;
                 r[] = DateTime.Now;
                 r[] = ;
                 dt.Rows.Add(r);
             }
             BulkToDB(dt);
             context.Response.Write(BulkToDB(dt) ? "ok" : "error");
             context.Session["dataTable"] = dt;
         }

         public void BulkToDB(DataTable dt)
         {
             SqlConnection sqlConn = new SqlConnection(ConfigurationManager.AppSettings["ConnString"]);
             SqlBulkCopy bulkCopy = new SqlBulkCopy(sqlConn);
             bulkCopy.DestinationTableName = "ClassRoomAccount";//数据库表名
             bulkCopy.BatchSize = dt.Rows.Count;
             try
             {
                 sqlConn.Open();
                 )
                     bulkCopy.WriteToServer(dt);
             }
             catch (Exception ex)
             {
                 new AppException("批量生成直播室账号异常", ex);
             }
             finally
             {
                 sqlConn.Close();
                 if (bulkCopy != null)
                     bulkCopy.Close();
             }
         }

         public DataTable GetTableSchema()
         {
             DataTable dt = new DataTable();
             dt.Columns.AddRange(new DataColumn[]{
                 new DataColumn("AccountId",typeof(int)),
                 new DataColumn("AccountName",typeof(string)),
                 new DataColumn("Password",typeof(string)),
                 new DataColumn("ClassRoomId",typeof(Guid)),
                 new DataColumn("AddDate",typeof(DateTime)),
                 new DataColumn("IsActive",typeof(int))
             });//数据库表结构
             return dt;
         }
         public bool IsReusable
         {
             get
             {
                 return false;
             }
         }
     }
 }

Asp.Net使用Bulk批量插入数据的更多相关文章

  1. asp.net Ibatis.net 批量插入数据ORACLE

    在开发中我们有时会遇到需要批量插入数据,最普通的就是每次 插入一条.但是当数据量大道一定的地步会很影响性能.下面例子示范了ibatis.net批量插入 ibatis.net 的XML文件里面使用ite ...

  2. php-elasticsearch bulk批量插入数据

    1.单条插入 <?php include '../vendor/Elasticsearch/autoload.php'; $a['hosts'] = array( #需要用户名时 http:// ...

  3. sql 中的Bulk和C# 中的SqlBulkCopy批量插入数据 ( 回顾 and 粗谈 )

    通常,我们会对于一个文本文件数据导入到数据库中,不多说,上代码. 首先,表结构如下.   其次,在我当前D盘中有个文本文件名为2.txt的文件. 在数据库中,可以这样通过一句代码插入. Bulk in ...

  4. C#批量插入数据到Sqlserver中的四种方式

    我的新书ASP.NET MVC企业级实战预计明年2月份出版,感谢大家关注! 本篇,我将来讲解一下在Sqlserver中批量插入数据. 先创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的 ...

  5. C#批量插入数据到Sqlserver中的三种方式

    本篇,我将来讲解一下在Sqlserver中批量插入数据. 先创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的是GUID,表中没有创建任何索引.GUID必然是比自增长要快的,因为你生 成 ...

  6. SQLServer 批量插入数据的两种方法

    SQLServer 批量插入数据的两种方法-发布:dxy 字体:[增加 减小] 类型:转载 在SQL Server 中插入一条数据使用Insert语句,但是如果想要批量插入一堆数据的话,循环使用Ins ...

  7. C#_批量插入数据到Sqlserver中的四种方式

    先创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的是GUID,表中没有创建任何索引.GUID必然是比自增长要快的,因为你生成一个GUID算法所花的时间肯定比你从数据表中重新查询上一条记 ...

  8. SQLServer使用表值参数,高性能批量插入数据

    记得前段时间帮同事写了个解析账号并入库的小工具,来批量导入账号信息,账号量相当大,程序每读取一条记录便执行一次insert来插入数据,整整跑了一下午才把账号全部入库. 今天又接到同事类似的需求,不过这 ...

  9. C# 之 批量插入数据到 SQLServer 中

    创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的是GUID,表中没有创建任何索引.GUID必然是比自增长要快.而如果存在索引的情况下,每次插入记录都会进行索引重建,这是非常耗性能的.如 ...

随机推荐

  1. linux学习记录 常用指令大全

    1.开启关闭服务器(即时生效): service iptasbles start service iptasbles stop 2.在开启了防火墙时,做如下设置,开启相关端口, 修改/etc/sysc ...

  2. 解决ActiveX Control异常:"没有注册类(异常来自 HRESULT:0x80040154(REGDB_E_CLASSNOTREG))"

    问题背景: 1.我们的程序是用winform调用unity web player 插件来作为播放器在客户端播放动画文件的. 2.播放器是由我们的客户端程序调用的 3.客户端程序默认是以管理员身份启动的 ...

  3. cookie那些事

    本文面向对cookie有基本了解的读者,小白出门左转   设置cookie (HTTP 响应头) Set-Cookie: {name}={value};path={path};domain={doma ...

  4. js的 new image()---转

    创建一个Image对象:var a=new Image(); 定义Image对象的src: a.src=”xxx.gif”;    这样做就相当于给浏览器缓存了一张图片. 图像对象: 建立图像对象:图 ...

  5. CGContext

    CGContext又叫图形上下文,相当于一块画布,以堆栈形式存放,只有在当前 context上绘图才有效.iOS有分多种图形上下文,其中UIView自带提供的在drawRect:方法中通过 UIGra ...

  6. 省市联动JQ封装比较简洁调用的方法

    前言 因为省市联动的需求在每个项目几乎存在,所以本人也对此在web页面通过封装比较简洁的JQ方法循环判断调用调用后台获取数据再绑定到Select表单上.如果对代码有什么疑问或者更好办法可以在评论区留言 ...

  7. Ubuntu安装samba服务器

    一.安装软件 sudo apt-get install samba 二.配置samba服务器/etc/samba/smb.conf 把默认的配置文件备份,按如下修改配置文件 [global] work ...

  8. WordPress插件制作笔记(三)---Stars Comments Article

    wp 文章星级评价 插件 下载地址4:http://pan.baidu.com/s/1eQnGIGU [articles_star_vote_score_optiontable_serialize_c ...

  9. project euler 12 Highly divisible triangular number

    Highly divisible triangular number Problem 12 The sequence of triangle numbers is generated by addin ...

  10. mysql 针对单张表的备份与还原

    A.MySQL 备份工具xtrabackup 的安装 . percona 官方xtrabackup 的二进制版本:二进制版本解压就能用了. . 解压xtrabackup & 创建连接 -Lin ...