我正在导入Excelsheet到sql服务器数据库中,我需要检查某些东西在导入工作表之前,例如我有一个名为Passport的列,它必须具有仅以字母开头的值,并且必须将剩余的字符作为数字(仅限于)。如何比较使用SqlBulkCopy时excel单元格值的值?
DataTable dt7 = new DataTable();
dt7.Load(dr);
DataRow[] ExcelRows = new DataRow[dt7.Rows.Count];
// Bulk Copy to SQL Server
using (SqlBulkCopy bulkCopy = new SqlBulkCopy(sqlConnectionString))
{
bulkCopy.DestinationTableName = "ExcelTable";
dt7.Rows.CopyTo(ExcelRows, 0);
for (int i = 0; i < ExcelRows.Length; i++)
{
if (ExcelRows[i]["data"] == DBNull.Value)
{
// Include any actions to perform if there is no date
//ExcelRows[i]["data"] = Convert.ToString(0);
}
else
{
DateTime oldDate = Convert.ToDateTime(ExcelRows[i]["data"]).Date;
DateTime newDate = Convert.ToDateTime(oldDate).Date;
ExcelRows[i]["data"] = newDate.ToString("yyyy/MM/dd");
}
}
bulkCopy.WriteToServer(ExcelRows);
哪里是上面代码中的护照栏? – andy
所以你需要在BCP之前检查它?使用查询/ SP在数据库中执行它可以吗?因为使用SQL Server内置函数应该相对简单。 – OzrenTkalcecKrznaric
@Anandkumar它不是我要添加护照我,我刚刚发布了这段代码,以显示我用什么方法上传excel – Arbaaz