1. 程式人生 > 實用技巧 >C#中System.DBNull的問題

C#中System.DBNull的問題

在使用 DataTable 的時候,經常會出現欄位值是System.DBNull 的情況,如果不做判斷就會丟擲一下異常提示:

 // 如果沒有輸入長度限制值或長度值解析失敗,則預設不做限制,長度判斷值設定為整數最大值
                    int  length = 0;
                    length = Int32.TryParse(((item["LengthConstraint"])) ? "" : item["LengthConstraint"].ToString(), out length) ? length : Int32.MaxValue;

注意:System.DBNull 和 null 是不一樣的,兩者用 == 或者 equals 判斷返回的是 false。

下面的示例呼叫 DBNull.Value.Equals 方法來確定聯絡人資料庫中的資料庫欄位是否具有有效的值如果是這樣,則將欄位值追加到標籤中的字串輸出

參考連結:https://docs.microsoft.com/zh-cn/dotnet/api/system.dbnull.value?view=netcore-3.1

private void OutputLabels(DataTable dt)
{
   string label;

   // Iterate rows of table
foreach (DataRow row in dt.Rows) { int labelLen; label = String.Empty; label += AddFieldValue(label, row, "Title"); label += AddFieldValue(label, row, "FirstName"); label += AddFieldValue(label, row, "MiddleInitial"); label += AddFieldValue(label, row, "LastName
"); label += AddFieldValue(label, row, "Suffix"); label += "\n"; label += AddFieldValue(label, row, "Address1"); label += AddFieldValue(label, row, "AptNo"); label += "\n"; labelLen = label.Length; label += AddFieldValue(label, row, "Address2"); if (label.Length != labelLen) label += "\n"; label += AddFieldValue(label, row, "City"); label += AddFieldValue(label, row, "State"); label += AddFieldValue(label, row, "Zip"); Console.WriteLine(label); Console.WriteLine(); } } private string AddFieldValue(string label, DataRow row, string fieldName) { if (! DBNull.Value.Equals(row[fieldName])) return (string) row[fieldName] + " "; else return String.Empty; }