gpt4 book ai didi

c# - 使用 SqlBulkCopy 在 asp.net 中上传 Excel 文件

转载 作者:太空宇宙 更新时间:2023-11-03 15:08:45 26 4
gpt4 key购买 nike

我正在使用以下代码在 asp.net c# 中上传 excel 文件。它工作正常,但问题是在 excel 文件中,某些列值始终是数字,如果其中一些数字值是文本格式,则它正在上传 null值(value)。这是我的代码 - 请提出任何建议。

if (!Convert.IsDBNull(FileUpload.PostedFile) &
FileUpload.PostedFile.ContentLength > 0)
{
//FIRST, SAVE THE SELECTED FILE IN THE ROOT DIRECTORY.
FileUpload.SaveAs(Server.MapPath(".") + "\\" + FileUpload.FileName);
// File.Delete(Server.MapPath(FileUpload.FileName));
SqlBulkCopy oSqlBulk = null;

// SET A CONNECTION WITH THE EXCEL FILE.
OleDbConnection myExcelConn = new OleDbConnection(
"Provider=Microsoft.ACE.OLEDB.12.0; " +
"Data Source=" + Server.MapPath(".") + "\\" + FileUpload.FileName +
";Extended Properties=Excel 12.0;");
try
{
myExcelConn.Open();

// GET DATA FROM EXCEL SHEET.
OleDbCommand objOleDB =
new OleDbCommand("SELECT SSS.*,'" + Session["vUserName"].ToString() + "' FROM [Sheet1$] SSS", myExcelConn);

// READ THE DATA EXTRACTED FROM THE EXCEL FILE.
OleDbDataReader objBulkReader = null;
objBulkReader = objOleDB.ExecuteReader();

// SET THE CONNECTION STRING.
// con = new SqlConnection(dbcon);

using (con = new SqlConnection(dbcon))
{
con.Open();

// FINALLY, LOAD DATA INTO THE DATABASE TABLE.
oSqlBulk = new SqlBulkCopy(con);
oSqlBulk.DestinationTableName = "tmpStuffing"; // TABLE NAME.

oSqlBulk.WriteToServer(objBulkReader);
}

lblConfirm.Text = "DATA IMPORTED SUCCESSFULLY.";
lblConfirm.Attributes.Add("style", "color:green");
}
catch (Exception ex)
{
lblConfirm.Text = ex.Message;
lblConfirm.Attributes.Add("style", "color:red");
}
finally
{
// CLEAR.
oSqlBulk.Close();
oSqlBulk = null;
myExcelConn.Close();
myExcelConn = null;
}
}

最佳答案

欢迎来到处理 Excel 怪癖的有趣和令人兴奋的世界,以及为什么使用 Excel 电子表格作为数据源是个坏主意。遗憾的是,您需要做更多的工作才能正常工作。

您需要检查每一行并对每一列执行适当的类型转换。最简单的可能是将源数据读入 DataTable 并将其传递给 WriteToServer 方法。

所以...创建一个兼容的 DataTable 并通过使用 Read() 遍历 Ole IDataReader 实例来填充它各种 Get*() 方法来读取字段数据。当它无法读取一个数字,因为它是一个字符串时,使用 Int32.TryConvert(...) 或类似的方法将字符串转换为正确的数字格式。一旦到达数据末尾(Read() 返回 false),DataTable 就可以使用 SqlBulkCopy 转储到 SQL 服务器与您在上面所做的方式相同。

一个快捷方式是使用 as 关键字来检测类型错误,并使用 ?? 空合并运算符来调用类型转换:

int? num = (reader.Item[1] as int?) ?? ParseInt(reader.GetString(1));

或者,如果可能,您可以使用扩展方法进行转换:

public static int? AsInt32(this IDataReader rdr, int index)
{
Type ft = rdr.GetFieldType(index);
if (ft == typeof(int))
return rdr.GetInt32(index);
else if (ft == typeof(string))
{
int v;
if (Int32.TryParse(rdr.GetString(index), out v))
return v;
}
else if (ft == typeof(object))
{
object fv = rdr.GetValue(index);
int? v = fv as int?;
if (v != null)
return v.Value;
}

return null;
}

AsString 添加一个类似的(这相当简单),您可以使用类似这样的方法将 Excel IDataReader 转换为 DataTable :

public DataTable ImportData(IDataReader reader)
{
DataTable table = new DataTable();
table.Columns.Add("ID", typeof(int));
table.Columns.Add("UserName", typeof(string));

int rownum = 0;
while (reader.Read())
{
++rownum;
int? id = reader.AsInt32(0);
if (id == null)
throw new Exception(string.Format("Invalid ID on row {0}, value: {1}", rownum, reader.GetValue(0)));

string name = reader.AsString(1);

table.Rows.Add(id.Value, name);
}

return table;
}

关于c# - 使用 SqlBulkCopy 在 asp.net 中上传 Excel 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42128419/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com