当我的网站获得以下代码时,它会如下所示:
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) { }