首页 >后端开发 >C++ >如何处理 C# 中的'对象无法从 DBNull 转换为其他类型”错误?

如何处理 C# 中的'对象无法从 DBNull 转换为其他类型”错误?

DDD
DDD原创
2025-01-11 15:06:421074浏览

How to Handle

无法将对象从 DBNull 转换为其他类型

错误说明:

错误消息“无法将对象从 DBNull 转换为其他类型”表明尝试将 DBNull 值(表示数据库中的空值)转换为不可为空的类型(在本例中为 Int64)失败了。

错误原因:

在提供的代码中,以下行尝试将名为“op_Id”的输出参数的值转换为 Int64:

<code>DataTO.Id = Convert.ToInt64(dataAccCom.GetParameterValue(IDbCmd, "op_Id"));</code>

如果存储过程为此参数返回了 DBNull 值,则转换将失败并导致错误。

解决方案:

要解决此问题,请在尝试转换之前显式检查输出参数的值是否为 DBNull。如果是 DBNull,则将 null 或默认值赋给 DataTO 对象中对应的属性。以下是更新后的代码:

<code>var outputParam = dataAccCom.GetParameterValue(IDbCmd, "op_Id");
if (outputParam != DBNull.Value)
    DataTO.Id = Convert.ToInt64(outputParam);
else
    DataTO.Id = null; // 或分配默认值,例如 0 或 -1</code>

这种修改确保了在处理数据库中可能存在的空值时,代码的健壮性。 使用 outputParam != DBNull.Value!(outputParam is DBNull) 更简洁明了,并且在性能上没有显着差异。 选择将 DataTO.Id 设为 null 还是一个默认值取决于您的应用程序逻辑和 DataTO.Id 属性的类型是否允许为空。

以上是如何处理 C# 中的'对象无法从 DBNull 转换为其他类型”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn