首页 >后端开发 >C++ >如何在 C# 中安全地将 DBNull 值转换为字符串?

如何在 C# 中安全地将 DBNull 值转换为字符串?

Susan Sarandon
Susan Sarandon原创
2025-01-25 10:07:101029浏览

How to Safely Cast DBNull Values to Strings in C#?

在 C# 中将空值转换为字符串

尝试将 System.DBNull 对象转换为 System.String 通常会导致错误,此错误通常发生在从数据库检索数据时。原始代码尝试直接将 DBNull 值强制转换为字符串,导致异常。

为了解决这个问题,代码被修改为在转换为字符串之前检查 DBNull:

<code class="language-csharp">if (accountNumber is DBNull)
{
    return string.Empty;
}
else
{
    return accountNumber.ToString();
}</code>

但是,使用泛型函数有更优雅的解决方案:

<code class="language-csharp">return ConvertFromDBVal<string>(accountNumber);</code>

该函数定义如下:

<code class="language-csharp">public static T ConvertFromDBVal<T>(object obj)
{
    if (obj == null || obj == DBNull.Value)
    {
        return default(T); // 返回该类型的默认值
    }
    else
    {
        return (T)obj;
    }
}</code>

此函数优雅地处理将 DBNull 值转换为所需类型的转换,如果需要,则返回该类型的默认值。

以上是如何在 C# 中安全地将 DBNull 值转换为字符串?的详细内容。更多信息请关注PHP中文网其他相关文章!

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