zoukankan      html  css  js  c++  java
  • 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 += "
    ";
          label += AddFieldValue(label, row, "Address1");
          label += AddFieldValue(label, row, "AptNo");
          label += "
    ";
          labelLen = label.Length;
          label += AddFieldValue(label, row, "Address2");
          if (label.Length != labelLen)
             label += "
    ";
          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;
    }
  • 相关阅读:
    算法分析之最大子段求和(一)
    算法分析之动态规划
    算法分析之数字三角形逆推
    算法分析之递归与分治策略
    算法分析之汉诺塔问题
    算法分析之猴子吃桃
    基于python玩转人工智能最火框架之TensorFlow人工智能&深度学习介绍
    win10 64下anaconda4.2.0(python3.5)
    PYTHON 爬虫 baidu美女图片
    falkonry
  • 原文地址:https://www.cnblogs.com/runningRain/p/13801591.html
Copyright © 2011-2022 走看看