主页 > 知识库 > Asp.Net使用Bulk实现批量插入数据

Asp.Net使用Bulk实现批量插入数据

热门标签:柳州电销机器人公司 百度地图怎样做地图标注 腾讯地图标注手机 电销语音机器人型号参数 征途美甲店地图标注 太原400电话上门办理 昆明语音电销机器人价格 浦发电话机器人提醒还款 400电话如何申请取消

本文实例讲述了Asp.Net使用Bulk实现批量插入数据的方法,分享给大家供大家参考之用。具体方法如下:

主要功能代码如下:

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();
      for (int i = 0; i  Count; i++)//循环往DataTable中赋值
      {
        DataRow r = dt.NewRow();
        r[1] = ran.Next(10000000, 100000000);
        r[2] = ran.Next(10000000, 100000000);
        r[3] = classRoomId;
        r[4] = DateTime.Now;
        r[5] = 1;
        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();
        if (dt != null  dt.Rows.Count != 0)
          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程序设计有所帮助。

您可能感兴趣的文章:
  • C#.NET中如何批量插入大量数据到数据库中
  • C#/.Net 中快速批量给SQLite数据库插入测试数据
  • asp.net新闻列表生成静态页之批量和单页生成
  • 在ASP.NET 2.0中操作数据之六十二:GridView批量更新数据
  • 在ASP.NET 2.0中操作数据之六十四:GridView批量添加数据
  • 在ASP.NET 2.0中操作数据之三十七:DataList批量更新
  • ajax readyState的五种状态详解
  • AJAX(XMLHttpRequest.status)状态码
  • javascript学习笔记(七)Ajax和Http状态码
  • asp.net线程批量导入数据时通过ajax获取执行状态

标签:兰州 新疆 德阳 白山 阳泉 天门 张家界 江苏

巨人网络通讯声明:本文标题《Asp.Net使用Bulk实现批量插入数据》,本文关键词  Asp.Net,使用,Bulk,实现,批量,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Asp.Net使用Bulk实现批量插入数据》相关的同类信息!
  • 本页收集关于Asp.Net使用Bulk实现批量插入数据的相关信息资讯供网民参考!
  • 推荐文章