48

我有一个DateTime?我正在尝试使用DbParameter. 我正在像这样创建参数:

DbParameter datePrm = updateStmt.CreateParameter();
datePrm.ParameterName = "@change_date";

然后我想把 s 的值DateTime?放入dataPrm.Valuewhile 占nulls。

起初我以为我会很聪明:

datePrm.Value = nullableDate ?? DBNull.Value;

但这因错误而失败

操作员 '??' 不能应用于“System.DateTime?”类型的操作数?和'System.DBNull'

所以我猜这只有在第二个参数是第一个参数的不可空版本时才有效。所以我去了:

datePrm.Value = nullableDate.HasValue ? nullableDate.Value : DBNull.Value;

但这也不起作用:

无法确定条件表达式的类型,因为 'System.DateTime' 和 'System.DBNull' 之间没有隐式转换

但我不想在这些类型之间进行转换!

到目前为止,我唯一可以开始工作的是:

if (nullableDate.HasValue)
  datePrm.Value = nullableDate.Value;
else
  datePrm.Value = DBNull.Value;

这真的是我写这篇文章的唯一方法吗?有没有办法让使用三元运算符的单线工作?

更新:我真的不明白为什么?版本不起作用。MSDN 说:

这 ??运算符如果不为空则返回左操作数,否则返回右操作数。

这正是我想要的!

Update2:嗯,最后很明显:

datePrm.Value = nullableDate ?? (object)DBNull.Value;
4

6 回答 6

64

啊哈!我找到了比@Trebz 更有效的解决方案!

datePrm.Value = nullableDate ?? (object)DBNull.Value;
于 2008-10-20T15:49:20.123 回答
6

如果您使用 SQLServer,System.Data.SqlTypes命名空间包含一些实用程序类,可以避免烦人的类型转换。例如,而不是这个:

var val = (object) "abc" ?? DBNull.Value;

你可以这样写:

var val = "abc" ?? SqlString.Null;
于 2015-03-25T14:23:14.227 回答
5

如果你使用它会起作用

datePrm.Value = nullableDate.HasValue ? (object)nullableDate.Value : DBNull.Value;
于 2008-10-20T15:36:09.430 回答
5

如果您使用的是 C# 3.0,您可以创建一个扩展方法来轻松完成此操作:

public static class DBNullableExtensions
{
    public static object ToDBValue<T>(this Nullable<T> value) where T:struct
    { 
        return value.HasValue ? (object)value.Value : DBNull.Value;
    }
}


class Program
{
    static void Main(string[] args)
    {
        int? x = null;

        Console.WriteLine(  x.ToDBValue() == DBNull.Value );
    }
}
于 2008-10-20T15:40:04.057 回答
1

我认为您第二次尝试的错误是由于 nullableDate.Value 和 DBNull.Value 是不同的类型,并且三元运算符需要在两种情况下都选择一种类型来返回。我没有测试这个的环境,但我认为这应该适合你:

datePrm.Value = nullableDate.HasValue ? (object)nullableDate.Value : (object)DBNull.Value;
于 2008-10-20T15:36:13.033 回答
0

我这样做的方式是,我有一个静态实用程序类,它只是通过并检查参数值是否为空,然后我将值设置为执行 DBNull。我只是在调用 Execute 之前这样做。

于 2008-10-20T15:38:11.393 回答