c# – “对象不能从DBNull转换为其他类型”

当我的网站获得以下代码时,它会如下所示:

system.invalidCastException: Object cannot be cast from dbnull to other types.

为了简洁起见,我只显示相关的代码(这是我给出的4000 LOC文件).

if (dr["STAGE"] is dbnull)
{
    dto.Stage = 1; // This is the line throwing the exception,according to stack trace
}
else
{
    dto.Stage = Convert.ToInt32(dr["STAGE"]);
}

这里,dr是一个DaTarow对象,它是对数据库查询的结果,dto是一个基本类,只保存一些属性,其中dto.Stage是一个int成员.

我用同样的错误信息查看了其他问题,但大多数人似乎建议“检查是否是dbnull”,我已经在做.

那么有人可以提出解决方案吗?

解决方法

使用==而不是
if (dr["STAGE"] == dbnull.Value)
{

}

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...