SQLBulkCopy引发InvalidOperationException Nullable Ints

c# invalidoperationexception nullable sql sqlbulkcopy

我有一个我试图上传的DataTable,但是我遇到了以下异常:
“数据源中String类型的给定值无法转换为指定目标列的int类型。”

我认为可能这样做的唯一原因是DataTable中有空单元格被上传到INT类型的列。我尝试切换DBNull.Value的所有空值,但这似乎不适用于此特定列。上传过程如下:

private void UploadTable(string tableName, DataTable table)
    {
        foreach (DataRow r in table.Rows)
        {
            foreach (DataColumn c in table.Columns)
                if (r[c].ToString().Trim() == "")
                    r[c] = DBNull.Value;
        }

        using (SqlBulkCopy copy = new SqlBulkCopy(sqlCon))
        {

            copy.DestinationTableName = tableName;
            try
            {
                copy.WriteToServer(table);
            }
            catch (Exception ex)
            {
                lblError.Content = ex.ToString();
            }
        }
    }

我上传的架构是:

[dbo].[table](
[Date] [smalldatetime] NOT NULL,
[Dollar] [varchar](50) NULL,
[CName] [varchar](100) NULL,
[tick] [varchar](10) NULL,
[id1] [varchar](10) NOT NULL,
[Total Quantity] [int] NULL,
[Quantity] [int] NULL
)

关于SQLBulkCopy和nullable int coolumns有什么特别之处我不知道吗?任何输入都表示赞赏。

一般承认的答案

错误的文件输入导致错误 - 其中包含小数,但不应该


热门答案

在将datacolumns添加到数据表时,是否将列类型指定为int




许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因
许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因