OleDbDataReader对象无法读取文件

时间:2014-10-15 12:05:38

标签: c# sql asp.net excel

我开发了一个功能,我将Excel工作表导入到表中。但是当我上传文件并单击按钮进行导入时。代码不起作用,并给我下面提到的错误。我尝试使用DataAdapter,但这也无法正常工作。请参阅以下错误: -

  

Microsoft Office Access数据库引擎找不到该对象   ' TableName&#39 ;.确保对象存在并拼写它   名称和路径名称正确。

此外,请参阅代码供您参考: -

 private void ImporttoSQL(string sPath)
{  
    string sSourceConstr1 = string.Format(@"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\AgentList.xls; Extended Properties=""Excel 8.0;HDR=YES;""", sPath);
    string sSourceConstr = string.Format(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=""Excel 12.0 Xml;HDR=YES;""", sPath);
    OleDbConnection sSourceConnection = new OleDbConnection(sSourceConstr);
    using (sSourceConnection)
    {
        string sql = string.Format("Select [Merchant_Name],[Store_Name],[Store_Address],[City] FROM [MerchantTempDetail]", "Sheet1$");
        OleDbCommand command = new OleDbCommand(sql, sSourceConnection);
        sSourceConnection.Open();
        conn.Open();
        using (OleDbDataReader dr = command.ExecuteReader())
        {
            using (SqlBulkCopy bulkCopy = new SqlBulkCopy(conn))
            {
                bulkCopy.DestinationTableName = "MerchantTempDetail";
                //You can mannualy set the column mapping by the following way.
                //  bulkCopy.ColumnMappings.Add("Mini_Category_Id", "Mini_Category_Id");
                //bulkCopy.ColumnMappings.Add("CategoryId", "CategoryId");
                bulkCopy.ColumnMappings.Add("Merchant_Name", "Merchant_Name");
                bulkCopy.ColumnMappings.Add("Store_Name", "Store_Name");
                bulkCopy.ColumnMappings.Add("Store_Address", "Store_Address");
                bulkCopy.ColumnMappings.Add("City", "City");
                bulkCopy.WriteToServer(dr);
            }
        }
    }
}

编辑代码: -

 public static void ExcelToSqlServerBulkCopy()
{
    // Connection String to Excel Workbook
    // Jet4
    string excelConnectionString = @"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=AgentList.xls; Extended Properties=""Excel 8.0;HDR=YES;""";
    // Ace Ole db 12
    string excelAceOleDb12ConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=AgentList.xls;Extended Properties=""Excel 8.0;HDR=YES;""";

    // Create Connection to Excel Workbook
    using (OleDbConnection connection = new OleDbConnection(excelAceOleDb12ConnectionString))
    {
        OleDbCommand command = new OleDbCommand("Select [Merchant_Name],[Store_Name],[Store_Address],[City] FROM [Sheet1$]", connection);
        // open excel
        connection.Open();
        // Create DbDataReader to Data Worksheet
        using (DbDataReader dr = command.ExecuteReader())
        {
            // SQL Server Connection String
            string sqlConnectionString = ConfigurationManager.ConnectionStrings["DefaultSQLConnectionString"].ConnectionString;
            // Bulk Copy to SQL Server
            using (SqlBulkCopy bulkCopy = new SqlBulkCopy(sqlConnectionString))
            {
                bulkCopy.DestinationTableName = "MerchantTempDetail";
                bulkCopy.WriteToServer(dr);
            }
        }
    }
}

protected void btnImport_Click(object sender, EventArgs e)
{
    if (FileUpload1.HasFile)
    {
        string sPath = Server.MapPath(FileUpload1.FileName);
        FileUpload1.SaveAs(sPath);

        ExcelToSqlServerBulkCopy();
    }
}

2 个答案:

答案 0 :(得分:0)

您需要为批量复制定义 2个连接一个用于Excel源另一个用于sql数据库。 (此代码已经过测试)如果您需要复制到内存数据表,请使用此example on MSDN

public static void ExcelToSqlServerBulkCopy ()
{
  // Connection String to Excel Workbook
  // Jet4
  string excelConnectionString = @"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=AgentList.xls; Extended Properties=""Excel 8.0;HDR=YES;""";
  // Ace Ole db 12
  string excelAceOleDb12ConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=AgentList.xls;Extended Properties=""Excel 8.0;HDR=YES;""";

  // Create Connection to Excel Workbook
  using (OleDbConnection connection = new OleDbConnection(excelAceOleDb12ConnectionString))
  {
    OleDbCommand command = new OleDbCommand("Select [Merchant_Name],[Store_Name],[Store_Address],[City] FROM [AgentList$]", connection);
    // open excel
    connection.Open ();        
    // Create DbDataReader to Data Worksheet
    using (DbDataReader dr = command.ExecuteReader ())
    {
      // SQL Server Connection String
      string sqlConnectionString = @"Data Source=.\SQLEXPRESS;Initial Catalog=StackOverflow;Integrated Security=True";
      // Bulk Copy to SQL Server
      using (SqlBulkCopy bulkCopy = new SqlBulkCopy (sqlConnectionString))
      {
        bulkCopy.DestinationTableName = "Q26382169";
        bulkCopy.WriteToServer (dr);
      }
    }
  }
}

使用上述变量名称的非常​​重要的细节:

  1. 必须先验地创建要复制到的数据库(StackOverflow)。
  2. 目标表(Q26382169)必须存在于该数据库,DDL琐碎,与Excel文件相同的列中。
  3. 由于您使用的是 HDR = YES 选项,因此Excel工作表的第一行必须包含指定的列名:Merchant_Name,Store_Name,Store_Address,City(不带[])
  4. OleDbCommand(AgentList $)
  5. 中工作表的名称

答案 1 :(得分:0)

最后通过调试解决了。

 private void ImporttoSQL(string sPath)
{
    string sSourceConstr1 = string.Format(@"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\AgentList.xls; Extended Properties=""Excel 8.0;HDR=YES;""", sPath);
    string sSourceConstr = string.Format(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=""Excel 12.0 Xml;HDR=YES;""", sPath);

    //   string sSource = string.Format(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + sPath + ";Extended Properties=Excel 8.0", sPath);

    // string sDestConstr = ConfigurationManager.ConnectionStrings["DBConnection"].ConnectionString;
    OleDbConnection sSourceConnection = new OleDbConnection(sSourceConstr);
    using (sSourceConnection)
    {
        SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["DefaultSQLConnectionString"].ConnectionString);
        string sql = "Select [Merchant_Name],[Store_Name],[Store_Address],[City] FROM [Sheet1$]";
        OleDbCommand command = new OleDbCommand(sql, sSourceConnection);
        sSourceConnection.Open();
        conn.Open();
        using (OleDbDataReader dr = command.ExecuteReader())
        {
            using (SqlBulkCopy bulkCopy = new SqlBulkCopy(conn))
            {
                bulkCopy.DestinationTableName = "MerchantTempDetail";
                bulkCopy.ColumnMappings.Add("Merchant_Name", "Merchant_Name");
                bulkCopy.ColumnMappings.Add("Store_Name", "Store_Name");
                bulkCopy.ColumnMappings.Add("Store_Address", "Store_Address");
                bulkCopy.ColumnMappings.Add("City", "City");
                 bulkCopy.WriteToServer(dr);
            }
        }
    }
}