C# ADO.NET: nulls and DbNull -- is there more efficient syntax?(C# ADO.NET:null 和 DbNull——有更高效的语法吗?)
问题描述
I've got a DateTime? that I'm trying to insert into a field using a DbParameter. I'm creating the parameter like so:
DbParameter datePrm = updateStmt.CreateParameter();
datePrm.ParameterName = "@change_date";
And then I want to put the value of the DateTime? into the dataPrm.Value while accounting for nulls.
I thought initially I'd be clever:
datePrm.Value = nullableDate ?? DBNull.Value;
but that fails with the error
Operator '??' cannot be applied to operands of type 'System.DateTime?' and 'System.DBNull'
So I guess that only works if the second argument is a non-nullable version of the first argument. So then I went for:
datePrm.Value = nullableDate.HasValue ? nullableDate.Value : DBNull.Value;
but that doesn't work either:
Type of conditional expression cannot be determined because there is no implicit conversion between 'System.DateTime' and 'System.DBNull'
But I don't want to convert between those types!
So far the only thing I can get to work is:
if (nullableDate.HasValue)
datePrm.Value = nullableDate.Value;
else
datePrm.Value = DBNull.Value;
Is that really the only way I can write this? Is there a way to get a one-liner using the ternary operator to work?
Update: I don't really get why the ?? version doesn't work. MSDN says:
The ?? operator returns the left-hand operand if it is not null, or else it returns the right operand.
That's exactly what I want!
Update2: Well it was kind of obvious in the end:
datePrm.Value = nullableDate ?? (object)DBNull.Value;
Ah ha! I found an even more efficient solution than @Trebz's!
datePrm.Value = nullableDate ?? (object)DBNull.Value;
这篇关于C# ADO.NET:null 和 DbNull——有更高效的语法吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:C# ADO.NET:null 和 DbNull——有更高效的语法吗?
基础教程推荐
- JSON.NET 中基于属性的类型解析 2022-01-01
- 如何动态获取文本框中datagridview列的总和 2022-01-01
- 首先创建代码,多对多,关联表中的附加字段 2022-01-01
- 在 VS2010 中的 Post Build 事件中将 bin 文件复制到物 2022-01-01
- 错误“此流不支持搜索操作"在 C# 中 2022-01-01
- 经典 Asp 中的 ResolveUrl/Url.Content 等效项 2022-01-01
- 是否可以在 asp classic 和 asp.net 之间共享会话状态 2022-01-01
- 全局 ASAX - 获取服务器名称 2022-01-01
- 从 VS 2017 .NET Core 项目的发布目录中排除文件 2022-01-01
- 将事件 TextChanged 分配给表单中的所有文本框 2022-01-01
