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. EffectiveC#2--为你的常量选择readonly而不是const

    1.对于常量,C#里有两个不同的版本: 编译时常量--效率相比更高些,但可维护性不好,保留的目的是为了性能.const关键字申明 public const int _Millennium = 2000 ...

  2. HTML基础知识笔记(二)

    HTML <img>标签 语法: <img src="图片地址" alt="下载失败时的替换文本" title = "提示文本&qu ...

  3. ListView加载两种以上不同的布局

    不同的项目布局(item layout) Listview一种单一的item 布局有时候不能完全满足业务需求,我们需要加载两种或两种以上不同的布局,实现方法很简单: 重写 getViewTypeCou ...

  4. CSS 设计彻底研究(一)(X)HTML与CSS核心基础

    第1章 (X)HTML与CSS核心基础 这一章重点介绍了4个方面的问题.先介绍了 HTML和XHTML的发展历程以及需要注意的问题,然后介绍了如何将CSS引入HTML,接着讲解了CSS的各种选择器,及 ...

  5. OpenCV——KNN分类算法 <摘>

    KNN近邻分类法(k-Nearest Neighbor)是一个理论上比较成熟的方法,也是最简单的机器学习算法之一. 这个算法首先贮藏所有的训练样本,然后通过分析(包括选举,计算加权和等方式)一个新样本 ...

  6. java基础知识4

    58.线程的基本概念.线程的基本状态以及状态之间的关系线程指在程序执行过程中,能够执行程序代码的一个执行单位,每个程序至少都有一个线程,也就是程序本身.Java中的线程有四种状态分别是:运行.就绪.挂 ...

  7. Onthink_项目后总结

    ---------------------------------------写代码不孤独__小小代(http://www.cnblogs.com/xiaoxiaodai/) 经过一段时间的沉寂,项目 ...

  8. Python即时网络爬虫项目: 内容提取器的定义(Python2.7版本)

    1. 项目背景 在Python即时网络爬虫项目启动说明中我们讨论一个数字:程序员浪费在调测内容提取规则上的时间太多了(见上图),从而我们发起了这个项目,把程序员从繁琐的调测规则中解放出来,投入到更高端 ...

  9. JS中各种宽度、高度、位置、距离总结

    1.window.screen 浏览器与屏幕的距离,screenX(screenLeft),screenY(screenTop) 2.window.scrollTo(x,y) 将纵向滚动条移动到相对于 ...

  10. Keil C51.uew

    /L15"Keil C51" Line Comment = // Block Comment On = /* Block Comment Off = */ Escape Char ...