首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >解释如何处理DBNull?

解释如何处理DBNull?
EN

Stack Overflow用户
提问于 2013-03-14 15:50:23
回答 2查看 704关注 0票数 2

我有一个可空的DateTime字段"BirthDate“,现有的代码就是以这样的方式处理这个问题的

代码语言:javascript
复制
info.BirthDate = (DateTime?)reader["Birthdate"];

这会导致“无效的强制转换”错误,并且会中断。好的,我理解这是因为空值的返回方式与sql不同,并且类型为"DBNull“。

解决这个问题的方法是

代码语言:javascript
复制
if (reader["Birthdate"] != DBNull.Value)
{
    info.Birthdate = (DateTime)reader["Birthdate"];
}

有人能解释一下为什么会这样吗?.我特别迷上了DBNull的DBNull部分。如果它作为DBNull返回,那么代码如何到达这个块内呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-03-14 15:52:29

DBNull是一个单身人士。只有一个例子。您可以使用DBNull.Value访问这个实例。比较检查DBNull(.Value)是否返回,如果未返回(!=),则它知道可以安全地将其转换为DateTime

来自MSDN

DBNull是一个单例类,这意味着只能存在这个类的实例。

或者,您可以使用Convert.IsDBNull方法:

代码语言:javascript
复制
if (!Convert.IsDBNull(reader["Birthdate"]))
{
    info.Birthdate = (DateTime)reader["Birthdate"];
}
票数 5
EN

Stack Overflow用户

发布于 2013-03-14 16:02:33

DBNull是一种类型,而不是值。正如@aKzenT所解释的,它是作为一个单例实现的,这意味着只能有一个这种类型的实例。获得该值的方法是通过静态.Value属性。

这使得比较变得很容易,因为任何DBNull实例在值和对另一个DBNull实例的引用上都是相等的。

另一种可能更有意义的检查方法是:

代码语言:javascript
复制
int columnIndex = reader.GetOrdinal("Birthdate");
if (!reader.IsDbNull(columnIndex)) // IsDbNull should have a string overload, but it does not.
{
    info.Birthdate = (DateTime)reader["Birthdate"];
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15413935

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档