我有一个DateTime?
,我试图使用DbParameter
插入字段。我正在创建这样的参数:
DbParameter datePrm = updateStmt.CreateParameter();
datePrm.ParameterName = "@change_date";
然后我想将DateTime?
的值放入dataPrm.Value
,同时考虑null
s。
我以为我最初很聪明:
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说:
??如果左侧操作数不为null,则返回左侧操作数,否则返回右侧操作数。
这正是我想要的!
Update2:最后有点明显:
datePrm.Value = nullableDate ?? (object)DBNull.Value;
答案 0 :(得分:62)
datePrm.Value = nullableDate ?? (object)DBNull.Value;
答案 1 :(得分:6)
如果您使用的是SQLServer,System.Data.SqlTypes
命名空间包含一些避免恼人的类型转换的实用程序类。例如,而不是:
var val = (object) "abc" ?? DBNull.Value;
你可以这样写:
var val = "abc" ?? SqlString.Null;
答案 2 :(得分:5)
如果您使用
,它会起作用datePrm.Value = nullableDate.HasValue ? (object)nullableDate.Value : DBNull.Value;
答案 3 :(得分: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 );
}
}
答案 4 :(得分:1)
我认为第二次尝试的错误是由于nullableDate.Value和DBNull.Value是不同的类型而三元运算符需要在两种情况下都选择一种类型返回。我没有环境来测试这个,但我认为这对你有用:
datePrm.Value = nullableDate.HasValue ? (object)nullableDate.Value : (object)DBNull.Value;
答案 5 :(得分:0)
我这样做的方法是,我有一个静态实用程序类,只是通过并检查参数值是否为null,然后我将值设置为DBNull。我在调用Execute之前就这样做了。