1

我使用 SqlBuldCopy 类将类型化数据集中的数据插入到我的 MSSQL 数据库中:

foreach (DataTable dt in ds.Tables)
{
    using (SqlBulkCopy bulkCopy = new SqlBulkCopy(conn)) 
    {
        bulkCopy.DestinationTableName = "dbo." + dt.TableName + "_neu";

        try
        {
            bulkCopy.WriteToServer(dt);
        }
        catch (Exception ex)
        {
            throw new FaultException("\n" + dt.TableName + ": " + ex.Message);
        }
    }
}

它工作得很好。但是当我将 DataTime.MinValue 插入我的数据库时,我得到了这个错误:SqlDateTime 溢出。必须介于 1753 年 1 月 1 日上午 12:00:00 和 9999 年 12 月 31 日晚上 11:59:59 之间。有没有办法在 foreach 中这样说:如果数据集中的 DateTime 字段值为 DateTime.MinValue,则不要将数据集中的 DateTime 字段插入我的数据库中?

最好的祝福

4

3 回答 3

1

我认为您需要确保数据表中没有 DateTime.MinValue - 您是否控制该表的数量?

如果是这样,不要将 DateTime.MinValue 存储在 DateTime 字段中,而是使用SqlDateTime.MinValue。或者,如果您希望将 NULL 存储到数据库中,请将 DBNull 存储在数据表中。

于 2009-12-15T09:23:22.670 回答
1
public void ChangeDateTimeColumn(DataTable newDataTable)
{
    for (int i = 0; i < newDataTable.Rows.Count; i++)
    {
        for (int j = 0; j < newDataTable.Columns.Count; j++)
        {
            DataColumn dc = newDataTable.Columns[j];
            if (dc.DataType == typeof(DateTime))
            {
                string name = dc.ColumnName;
                DataRow row = newDataTable.Rows[i];
                if (row[name] != null && row[name].ToString().Trim() != "")
                {
                    DateTime value = (DateTime)row[name];
                    if (value < (DateTime)SqlDateTime.MinValue)
                    {
                        row[name] = (DateTime)SqlDateTime.MinValue;
                    }
                    else if ((DateTime)SqlDateTime.MaxValue < value)
                    {
                        row[name] = (DateTime)SqlDateTime.MaxValue;
                    }
                }
            }
        }
    }
} 
于 2015-07-14T04:59:24.707 回答
0

如果您有 SQL Server 2008 并且不介意存储 MinValue ,您可以使用DateTime2来解决这个问题。

于 2009-12-15T09:35:37.307 回答