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

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

Susan Sarandon
发布: 2025-01-25 10:07:10
原创
962 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板