导入到SQL Server后在数据库中显示额外的行

时间:2019-05-13 08:25:14

标签: c# asp.net sql-server excel database

我正在构建一个需要以下功能的程序:

  • 将Excel文件导入数据库-检查
  • 避免重复---处理
  • 忽略Excel文件标题和底部的某些行---这就是我想问的人

这是我的代码

protected void Upload_Click(object sender, EventArgs e)
{
    string excelPath = Server.MapPath("~/Nova pasta/") + Path.GetFileName(FileUpload1.PostedFile.FileName);

    string filepath = Server.MapPath("~/Nova pasta/") + Path.GetFileName(FileUpload1.FileName);
    string filename = Path.GetFileName(filepath);

    FileUpload1.SaveAs(excelPath);

    string strConnection = @"Data Source=PEDRO-PC\SQLEXPRESS;Initial Catalog=costumizado;Persist Security Info=True;User ID=sa;Password=1234";
    string excelConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filepath + ";Extended Properties=\"Excel 12.0 Xml;HDR=NO,IMEX=1;\"";

    OleDbConnection excelConnection = new OleDbConnection(excelConnectionString);
    excelConnection.Open();

    DataTable schema = excelConnection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
    string sheetName = schema.Rows[0]["TABLE_NAME"].ToString();

    OleDbCommand cmd = new OleDbCommand("Select * from [" + sheetName + "]", excelConnection);
    OleDbDataReader dReader;
    dReader = cmd.ExecuteReader();

    using (SqlBulkCopy sqlBulk = new SqlBulkCopy(strConnection))
    {
        sqlBulk.ColumnMappings.Add(0,0);
        sqlBulk.ColumnMappings.Add(1,1);
        sqlBulk.ColumnMappings.Add(2,2);
        sqlBulk.ColumnMappings.Add(3,3);
        sqlBulk.DestinationTableName = "Dados";

        sqlBulk.WriteToServer(dReader);
    }

    excelConnection.Close();
}

我正在努力的是,我需要在我的代码中找到excel中的列,并忽略我不需要的行...

我认为这行就足够了:

sqlBulk.ColumnMappings.Add(0,0);
sqlBulk.ColumnMappings.Add(1,1);
sqlBulk.ColumnMappings.Add(2,2);
sqlBulk.ColumnMappings.Add(3,3);
sqlBulk.DestinationTableName = "Dados";

这是我要导入的表:

Excel tables

1 个答案:

答案 0 :(得分:0)

应对波动的源文件非常棘手。也许尝试将文件整体加载到原始表中,然后在加载表后调用proc,仅将与完整行匹配的列移动到产品表或最终表中。例如,仅从原始数据中选择,其中Data Mov,Data Valor,Descricao do Movimento和Valor em EUR不为空。如果需要,您可以根据需要添加更多验证,例如检查前两列的日期格式和最后一列的数值。我只是认为在SQL中比在.NET代码中做起来要容易。