错误说明:
错误消息“无法将对象从 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中文网其他相关文章!