aspx后台实现Excel导入到SqlServer中

拿来主义

 

 

private void Excel2Sql()
    {
        DataSet ds = new DataSet();

        try
        {
            //获取全部数据
            string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + @"Data Source=E:/t.xls;" + "Extended Properties=Excel 8.0;";
            OleDbConnection conn = new OleDbConnection(strConn);
            conn.Open();
            string strExcel = "";
            OleDbDataAdapter myCommand = null;
            strExcel = string.Format("select * from [{0}$]", "Sheet1");
            myCommand = new OleDbDataAdapter(strExcel, strConn);
            myCommand.Fill(ds, "tb_Test");
            conn.Close();

            //如果目标表不存在则创建
            string strSql = string.Format("if object_id('{0}')is null create table {0}(", "tb_Test");
            foreach (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(ConfigurationManager.AppSettings["ConnectionString"]))
            {
                try
                {
                    sqlconn.Close();
                }
                catch
                {
               
                }
                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(ConfigurationManager.AppSettings["ConnectionString"]))
            {
                //bcp.SqlRowsCopied += new System.Data.SqlClient.SqlRowsCopiedEventHandler(bcp_SqlRowsCopied);
                bcp.BatchSize = 100;    //每次传输的行数
                bcp.DestinationTableName = "tb_Test";
                bcp.WriteToServer(ds.Tables[0]);
            }
            Response.Write("<script>alert('success');</script>");
        }
        catch (Exception ex)
        {
            throw(ex);
        }
    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值