方式一:

实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环来拼接sql,这样做不但容易出错而且效率低下,最好的办法是使用bcp,也就是System.Data.SqlClient.SqlBulkCopy 类来实现。

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;
namespace ExcelToSQL
{
    public
partial class Form1 : Form
    {
       
public Form1()
       
{
           
InitializeComponent();
       
}
       
private void button1_Click(object sender, EventArgs e)
       
{
           
//测试,将excel中的student导入到sqlserver的db_test中,如果sql中的数据表不存在则创建

string connString = "server = (local); uid = sa; pwd = sa; database
= db_test";
           
System.Windows.Forms.OpenFileDialog fd = new
OpenFileDialog();  
           
if (fd.ShowDialog() ==
DialogResult.OK)  
           
{
               
TransferData(fd.FileName, "student", connString);
           
}  
       
}  

       
public void TransferData(string excelFile, string sheetName, string
connectionString)  
       
{  
           
DataSet ds = new DataSet();
           
try 
           
{
               
//获取全部数据
               
string strConn = "Provider = Microsoft.Jet.OLEDB.4.0;" + "Data
Source=" + excelFile + ";" + "Extended Properties = Excel
8.0;";  
               
OleDbConnection conn = new OleDbConnection(strConn);
               
conn.Open();
               
string strExcel = "";
               
OleDbDataAdapter myCommand =
null;  
               
strExcel = string.Format("select * from [{0}$]", sheetName);
               
myCommand = new OleDbDataAdapter(strExcel, strConn);
               
myCommand.Fill(ds, sheetName);
 
               
//如果目标表不存在则创建,excel文件的第一行为列标题,从第二行开始全部都是数据记录
               
string strSql = string.Format("if not exists(select * from
sysobjects where name = '{0}') create table {0}(",
sheetName);  
//以sheetName为表名
               
foreach (System.Data.DataColumn c in ds.Tables[0].Columns)
               
{  
                   
strSql += string.Format("[{0}] varchar(255),",
c.ColumnName);  
               
}  
               
strSql = strSql.Trim(',') +
")";  
 
               
using (System.Data.SqlClient.SqlConnection sqlconn = new
System.Data.SqlClient.SqlConnection(connectionString))

{
                   
sqlconn.Open();  
                   
System.Data.SqlClient.SqlCommand command =
sqlconn.CreateCommand();  
                   
command.CommandText =
strSql;  
                   
command.ExecuteNonQuery();

sqlconn.Close();
               
}  
               
//用bcp导入数据  
               
//excel文件中列的顺序必须和数据表的列顺序一致,因为数据导入时,是从excel文件的第二行数据开始,不管数据表的结构是什么样的,反正就是第
一列的数据会插入到数据表的第一列字段中,第二列的数据插入到数据表的第二列字段中,以此类推,它本身不会去判断要插入的数据是对应数据表中哪一个字段的

using (System.Data.SqlClient.SqlBulkCopy bcp = new
System.Data.SqlClient.SqlBulkCopy(connectionString))

{  
                   
bcp.SqlRowsCopied += new
System.Data.SqlClient.SqlRowsCopiedEventHandler(bcp_SqlRowsCopied);

bcp.BatchSize =
100;//每次传输的行数  
                   
bcp.NotifyAfter =
100;//进度提示的行数  
                   
bcp.DestinationTableName =
sheetName;//目标表  
                   
bcp.WriteToServer(ds.Tables[0]);
               
}  
           
}  
           
catch (Exception ex)  
           
{  
               
System.Windows.Forms.MessageBox.Show(ex.Message);

}
       
}  
 
       
//进度显示  
       
void bcp_SqlRowsCopied(object sender,
System.Data.SqlClient.SqlRowsCopiedEventArgs
e)  
       
{  
           
this.Text =
e.RowsCopied.ToString();  
           
this.Update();  
       

   
}  
}

 

方式二:

先将Excel文件转换成DataTable,然后再循环将记录插入到数据库表中,这种方式可以任由程序员来选择将哪列数据导入到数据表的哪个字段中
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;
using System.Data.SqlClient;
namespace ExcelToSQL
{
    public
partial class Form2 : Form
    {
       
public Form2()
       
{
           
InitializeComponent();
       
}
       
DataTable dt = new DataTable();
       
string connString = "server = (local); uid = sa; pwd = sa; database
= db_test";
       
SqlConnection conn;
       
private void button1_Click(object sender, EventArgs e)
       
{
           
System.Windows.Forms.OpenFileDialog fd = new
OpenFileDialog();
           
if (fd.ShowDialog() == DialogResult.OK)
           
{
               
string fileName = fd.FileName;
               
bind(fileName);
           
}
       
}
       
private void bind(string fileName)
       
{
           
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                
"Data Source=" + fileName + ";" +
                
"Extended Properties='Excel 8.0; HDR=Yes; IMEX=1'";
           
OleDbDataAdapter da = new OleDbDataAdapter("SELECT
*  FROM [student$]", strConn);
           
DataSet ds = new DataSet();
           
try
           
{
               
da.Fill(ds);
               
dt = ds.Tables[0];
               
this.dataGridView1.DataSource = dt;
           
}
           
catch (Exception err)
           
{
               
MessageBox.Show("操作失败!" + err.ToString());
           
}
       
}

      
//将Datagridview1的记录插入到数据库 
       
private void button2_Click(object sender, EventArgs e)
       
{
           
conn = new SqlConnection(connString);
           
conn.Open();
           
if (dataGridView1.Rows.Count > 0)
           
{
               
DataRow dr = null;
               
for (int i = 0; i < dt.Rows.Count; i++)
               
{
                   
dr = dt.Rows[i];
                   
insertToSql(dr);
               
}
               
conn.Close();
               
MessageBox.Show("导入成功!");
           
}
           
else
           
{
               
MessageBox.Show("没有数据!");
           
}
       
}
       
private void insertToSql(DataRow dr)
       
{
           
//excel表中的列名和数据库中的列名一定要对应
           
string name = dr["StudentName"].ToString();
           
string sex = dr["Sex"].ToString();
           
string no = dr["StudentIDNO"].ToString();
           
string major = dr["Major"].ToString();
           
string sql = "insert into student values('" + name + "','" + sex +
"','" + no + "','" + major
+"')";

SqlCommand cmd = new SqlCommand(sql,
conn);

cmd.ExecuteNonQuery();
       
}
    }
}

 

using System;
using System.Data;
using System.Windows.Forms;
using System.Data.OleDb;
namespace WindowsApplication2
{
  public partial class Form1 : Form
  {
    public Form1()
    {
      InitializeComponent();
    }
    private void button1_Click(object sender, EventArgs e)
    {
      //测试,将excel中的sheet1导入到sqlserver中
      string connString =
"server=localhost;uid=sa;pwd=sqlgis;database=master";
      System.Windows.Forms.OpenFileDialog fd = new
OpenFileDialog();
      if (fd.ShowDialog() == DialogResult.OK)
      {
        TransferData(fd.FileName, "sheet1", connString);
      }
    }
    public void TransferData(string excelFile, string sheetName,
string connectionString)
    {
      DataSet ds = new DataSet();
      try
      {
        //获取全部数据
        string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +
"Data Source=" + excelFile + ";" + "Extended Properties=Excel
8.0;";
        OleDbConnection conn = new OleDbConnection(strConn);
        conn.Open();
        string strExcel = "";
        OleDbDataAdapter myCommand = null;
        strExcel = string.Format("select * from [{0}$]",
sheetName);
        myCommand = new OleDbDataAdapter(strExcel, strConn);
        myCommand.Fill(ds, sheetName);
        //如果目标表不存在则创建
        string strSql = string.Format("if
object_id(&apos;{0}&apos;) is null
create table {0}(", sheetName);
        foreach (System.Data.DataColumn c in
ds.Tables[0].Columns)
        {
          strSql += string.Format("[{0}] varchar(255),",
c.ColumnName);
        }
        strSql =
strSql.Trim(&apos;,&apos;) +
")";
        using (System.Data.SqlClient.SqlConnection sqlconn = new
System.Data.SqlClient.SqlConnection(connectionString))
        {
          sqlconn.Open();
          System.Data.SqlClient.SqlCommand command =
sqlconn.CreateCommand();
          command.CommandText = strSql;
          command.ExecuteNonQuery();
          sqlconn.Close();
        }
        //用bcp导入数据
        using (System.Data.SqlClient.SqlBulkCopy bcp = new
System.Data.SqlClient.SqlBulkCopy(connectionString))
        {
          bcp.SqlRowsCopied += new
System.Data.SqlClient.SqlRowsCopiedEventHandler(bcp_SqlRowsCopied);

          bcp.BatchSize = 100;//每次传输的行数
          bcp.NotifyAfter = 100;//进度提示的行数
          bcp.DestinationTableName = sheetName;//目标表
          bcp.WriteToServer(ds.Tables[0]);

                       
sbc.DestinationTableName = "mobile_black "; //服务器上目标表的名称

sbc.BulkCopyTimeout = 180;  //设置允许超时时间为100秒

sbc.ColumnMappings.Add("mobile", "mobile"); //本地表和目标表列名

sbc.ColumnMappings.Add("ts_id", "ts_id");   //如果表有多个字段,下面继续添加

sbc.WriteToServer(dt);//插入数据

result = true;

        }
      }
      catch (Exception ex)
      {
        System.Windows.Forms.MessageBox.Show(ex.Message);
      }
    }
    //进度显示
    void bcp_SqlRowsCopied(object sender,
System.Data.SqlClient.SqlRowsCopiedEventArgs e)
    {
      this.Text = e.RowsCopied.ToString();
      this.Update();
    }
  }
}

主要代码:

System.Data.SqlClient.SqlBulkCopy类,让大数量插入到MSSQL数据库中可以很快搞定。

项目中一个表100W条数据,普通SQL插入语句,花了10多分钟。

使用System.Data.SqlClient.SqlBulkCopy插入,只用了几秒钟。

下面是主要的代码:

  1. //省略连接字符串
  2. SqlConnection conn = new
    SqlConnection(".....");
  3. conn.Open();
  4. //初始化类
  5. using
    (System.Data.SqlClient.SqlBulkCopy sqlBC =
    new
    System.Data.SqlClient.SqlBulkCopy(conn))
  6. {
  7. //获取需要导入的数据表
  8. DataTable dt = GetDataTable();
  9. //每10W条数据一个事物
  10. sqlBC.BatchSize = 100000;
  11. //超时时间
  12. sqlBC.BulkCopyTimeout = 60;
  13. //表名Users
  14. sqlBC.DestinationTableName =
    "dbo.Users";
  15. //字段对应,分表为原数据表字段名,和导入数据库的字段名
  16. sqlBC.ColumnMappings.Add("Access_ID",
    "MSSQL_ID");
  17. sqlBC.ColumnMappings.Add("Access_Name",
    "MSSQL_Name");
  18. //sqlBC.ColumnMappings.Add("Access_...",
    "MSSQL_...");
  19. //sqlBC.ColumnMappings.Add("Access_...",
    "MSSQL_...");
  20. //导入到数据库
  21. sqlBC.WriteToServer(dt);

将excel中的sheet1导入到sqlserver中的更多相关文章

  1. excel文件与txt文件互转,并且把excel里的数据导入到oracle中

    一.excel文件转换成txt文件的步骤 a.首先要把excel文件转换成txt文件 1.Excel另存为中已经包含了TXT格式,所以我们可以直接将Excel表格另存为TXT格式,但是最后的效果好像不 ...

  2. C# 将List中的数据导入csv文件中

    //http://www.cnblogs.com/mingmingruyuedlut/archive/2013/01/20/2849906.html C# 将List中的数据导入csv文件中   将数 ...

  3. 如何将数据库中的数据导入到Solr中

    要使用solr实现网站中商品搜索,需要将mysql数据库中数据在solr中创建索引. 1.需要在solr的schema.xml文件定义要存储的商品Field. 商品表中的字段为: 配置内容是: < ...

  4. MyEclipse中的项目导入到Eclipse中运行的错误解决

    之前用的myEclipse,后来把项目导入eclipse发现报错,将MyEclipse中的项目导入到Eclipse中运行,不注意一些细节,会造成无法运行的后果.下面就说说具体操作:导入后出现如下错误: ...

  5. sqlserver怎么将excel表的数据导入到数据库中

    在数据库初始阶段,我们有些数据在EXCEL中做好之后,需要将EXCEL对应列名(导入后对应数据库表的字段名),对应sheet(改名为导入数据库之后的表名)导入指定数据库, 相当于导入一张表的整个数据. ...

  6. 将*.sql数据库脚本导入到sqlserver中(sql文件导入sqlserver)

    在SqlServer中这个是用生成sql脚本生成的 要是在导入数据库用数据导入/导出向导导不进去 其实要用查询分析器来打开sql文件 然后执行就可以了

  7. python将oracle中的数据导入到mysql中。

    一.导入表结构.使用工具:navicate premium 和PowerDesinger 1. 先用navicate premium把oracle中的数据库导出为oracle脚本. 2. 在Power ...

  8. 使用navicat for sqlserver 把excel中的数据导入到sqlserver数据库

    以前记得使用excel向mysql中导入过数据,今天使用excel向sqlserver2005导入了数据,在此把做法记录一下 第一步:准备excel数据,在这个excel中有3个sheet,每个she ...

  9. excel数据导入到sqlserver中---------工作笔记

    调用页面: using System; using System.Collections.Generic; using System.Linq; using System.Web; using Sys ...

随机推荐

  1. LCD显示屏原理与应用

    1.什么是LCD? (1)LCD(Liquid Crystal Display)俗称液晶.(2)液晶是一种材料,液晶这种材料具有一种特点:可以在电信号的驱动下液晶分子进行旋转,旋转时会影响透光性,因此 ...

  2. 【Tools】Windows下Github的配置和使用

    1.在网址:http://windows.github.com/下载git软件,具体的安装步骤可以参见:Windows 系统下Git安装图解 2.同样根据上面的教程生成SSH key: 3.将publ ...

  3. JAVA嵌套类:静态嵌套类和非静态嵌套类

    1.内部类定义 内部类在维基百科的定义为:  面向对象编程中,内部类(又叫做嵌套类)是在另一个类或者接口中进行声明的类.内部类不同于子类(subclass).(译者注:wiki的注解有误,内部类和嵌套 ...

  4. Chrome profile manager

    由于Firefox有profile manager这么一说,所以自然联想到chrome应该也有. 默认chrome的profile manager被禁止了. 1. chrome://flags 2. ...

  5. 【游记】NOIP 2017

    时间:2017.11.11~2017.11.12 地点:广东省广州市第六中学 Day1 T1:看到题目,心想这种题目也能放在T1? 这个结论我之前遇到过至少3次,自己也简单证明过.初见是NOIP200 ...

  6. JS之document例题讲解2

    例题三.图片轮播 <body> <div style="width:1000px; height:250px; margin-top:30px"> < ...

  7. C#编写程序监测某个文件夹内是否有文件进行了增,删,改的动作?

    新建一个Console应用程序,项目名称为“FileSystemWatcher”,Copy代码进,编译后就可以用了.代码如下: using System; using System.Collectio ...

  8. fork与printf缓冲问题

    printf输出条件: (1) 调用fflush: (2) 缓冲区满了: (3) 遇到\n \r这些字符 (4) 遇到scanf这些要取缓冲区的: (5) 线程或者进程退出: fork之后会拷贝父进程 ...

  9. 2015多校第8场 HDU 5382 GCD?LCM! 数论公式推导

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5382 题意:函数lcm(a,b):求两整数a,b的最小公倍数:函数gcd(a,b):求两整数a,b的最 ...

  10. freemark基础知识

    前言:使用freemarker对应生成一个html文件,保存到磁盘,访问文件就不一定使用tomcat,可以使用nginx(http服务器)访问.可以使用freemaker工具生成.只生成一次,html ...