1

我正在尝试将Excel文件上传到SQL数据库并且在我的计算机上工作正常,但是一旦我上传到服务器它就会给我这个错误:

异常详细信息:System.Data.OleDb.OleDbException:Microsoft Jet 数据库引擎找不到对象“C:\Windows\SysWOW64\inetsrv\Book1.xls”。确保对象存在并且正确拼写其名称和路径名。

源错误:

在执行当前 Web 请求期间生成了未处理的异常。可以使用下面的异常堆栈跟踪来识别有关异常起源和位置的信息。

这是我的代码:

    protected void Button1_Click(object sender, EventArgs e)
    {
        string excelConnectionString = string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;HRD=YES;IMEX=1'", FileUpload1.PostedFile.FileName);
        using (OleDbConnection connection = new OleDbConnection(excelConnectionString))
        {
            OleDbCommand command = new OleDbCommand(("Select * FROM [Sheet1$]"), connection);
            connection.Open();
            using (DbDataReader dr = command.ExecuteReader())
            {
                using (SqlBulkCopy bulkCopy = new SqlBulkCopy("Data Source=WSCJTCSQ1;Initial Catalog=TestDB;Persist Security Info=True;User ID=test;Password=test"))
                {                  
                    bulkCopy.DestinationTableName = "CoaTest";                        
                    bulkCopy.ColumnMappings.Add("First Name", "fName");
                    bulkCopy.ColumnMappings.Add("Last Name", "lName");
                    bulkCopy.ColumnMappings.Add("Agency", "agency");
                    bulkCopy.WriteToServer(dr);
                }
            }
        }
        Label1.ForeColor = System.Drawing.Color.Red;
        Label1.Text = "Successfully Uploaded The New Roster";   
    }
4

2 回答 2

2
string file = string.Format("{0}\\{1}", Request.PhysicalApplicationPath,
Guid.NewGuid().ToString().Replace("-",string.Empty));

FileUpload1.SaveAs(file)

现在在您的导入代码中

string excelConnectionString = string.Format("Provider=Microsoft.Jet.OLEDB.4.0;
Data Source={0};Extended Properties='Excel 8.0;HRD=YES;IMEX=1'", file);
于 2013-09-04T21:32:46.183 回答
0

在连接到它之前,您需要将文件保存在服务器上,例如:

string sServerFilespec = ("C:\\ServerFolder\\" + System.IO.Path.GetFileName(FileUpload1.PostedFile.FileName));
FileUpload1.PostedFile.FileName.SaveAs(sServerFilespec);
于 2013-09-04T21:15:19.330 回答