C#把Excel 导入到数据库

 我来答
Baby_原來
2016-01-06 · TA获得超过3402个赞
知道大有可为答主
回答量:1535
采纳率:94%
帮助的人:513万
展开全部

方式一:实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环来

拼接sql,这样做不但容易出错而且效率低下,最好的办法是使用bcp,也就是

System.Data.SqlClient.SqlBulkCopy 类来实现。 
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);       
               //如果目标表不存在则创建    excel文件的第一行为列标题,从第二行开始全部都是数据记录 
                string strSql = string.Format("if object_id('{0}') is null 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();            }       }    }

   

C# Excel导入数据库(二) 方式二: 

本文先将Excel文件转换成DataTable,然后再循环将记录插入到数据库表中,这种方式可以任由程序员来选择将哪列数据导入到数据表的哪个字段中 DataTable table =new DataTable(); 

//数据绑定到datagridview1 

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 [Sheet1$]", 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) {             if (dataGridView1.Rows.Count > 0)             { 
                DataRow dr = null; 
                for (int i = 0; i < dt.Rows.Count; i++) {                     dr = dt.Rows[i];                     insertToSql(dr);                 } 
                MessageBox.Show("导入成功!");             } 
            else { 
                MessageBox.Show("没有数据!");             }         } 
        private void insertToSql(DataRow dr) {             string name=dr["姓名"].ToString();             string age = dr["年龄"].ToString(); 
            string sql = "insert into sheet1 values('"+name+"','','"+age+"')";             SqlConnection conn = new SqlConnection();             SqlCommand cmd = new SqlCommand(sql,conn);             conn.Open(); 
            cmd.ExecuteNonQuery();             conn.Close();       
  }
帐号已注销
2011-01-08 · TA获得超过495个赞
知道小有建树答主
回答量:399
采纳率:0%
帮助的人:258万
展开全部
如果是SQL Server的话,简单的办法是你可以用SQL server自带的导入
你也可以用VS新建integration services项目,进行复杂迁移
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
小飞侠R65
推荐于2018-03-08 · 超过18用户采纳过TA的回答
知道答主
回答量:108
采纳率:100%
帮助的人:55.4万
展开全部
这个网上有很多,找找吧。
一般都是先获取execl的数据导入到dataset中,再把dataset中的数据库insert到数据库(这部分应该不用说了吧)。
需要注意一点的是:execl 2003和2007以上的版本所用的引擎是不一样的。如下列。
//导入EXCEL
public void ImportExcel(string fileName )
{
//string fileName = "d:\\123.xls";
string excelStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileName + ";Extended Properties='Excel 8.0;HDR=YES;IMEX=1'";//execl 2003
//string excelStr = "Provider= Microsoft.Ace.OleDB.12.0;Data Source=" + fileName + ";Extended Properties='Excel 12.0;HDR=YES;IMEX=1'";//execl 2007以上(需要装个AccessDatabaseEngine引擎,网上找找)
DataSet ds = new DataSet();
using (System.Data.OleDb.OleDbConnection cn = new OleDbConnection(excelStr))
{
using (OleDbDataAdapter dr = new OleDbDataAdapter("SELECT * FROM [sheet1$]", excelStr))
{
dr.Fill(ds);
}
}
//插入到数据库
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
hewengao401
2011-01-07 · TA获得超过103个赞
知道小有建树答主
回答量:97
采纳率:0%
帮助的人:96万
展开全部
先导入到datatable中在插入数据库
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式