首頁 > 後端開發 > C++ > 如何有效處理 C# 中的「無法將類型為'System.DBNull'的物件轉換為類型為'System.String'」錯誤?

如何有效處理 C# 中的「無法將類型為'System.DBNull'的物件轉換為類型為'System.String'」錯誤?

Barbara Streisand
發布: 2025-01-25 10:11:08
原創
680 人瀏覽過

How Can I Effectively Handle

巧妙解決“無法將類型為“System.DBNull”的對象強制轉換為類型為“System.String””錯誤

在嘗試將DBNull值轉換為字符串時,經常會遇到“無法將類型為“System.DBNull”的對象強制轉換為類型為“System.String””的錯誤。一種處理方法是使用條件語句,如果值為DBNull則返回空字符串。但是,這種方法比較繁瑣且容易出錯。

更優雅的解決方案是使用一個泛型函數來處理從數據庫值到所需類型的轉換,如下所示:

public static T ConvertFromDBVal<T>(object obj)
{
    if (obj == null || obj == DBNull.Value)
    {
        return default(T); // 返回该类型的默认值
    }
    else
    {
        return (T)obj;
    }
}
登入後複製

此函數接收一個對像作為輸入,並以所需類型(在本例中為字符串)返迴轉換後的值。使用方法如下:

object accountNumber = 
          DBSqlHelperFactory.ExecuteScalar(connectionStringSplendidmyApp, 
                          CommandType.StoredProcedure, 
                          "spx_GetCustomerNumber", 
                          new SqlParameter("@id", id));
登入後複製
return ConvertFromDBVal<string>(accountNumber);
登入後複製

通過使用此泛型函數,您可以簡化代碼並消除對條件檢查的需求,確保類型安全並減少出錯的可能性。

以上是如何有效處理 C# 中的「無法將類型為'System.DBNull'的物件轉換為類型為'System.String'」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板