• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C#中System.DBNull的问题

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

 

在使用 DataTable 的时候,经常会出现字段值是 System.DBNull 的情况,如果不做判断就会抛出一下异常提示:

 // 如果没有输入长度限制值或长度值解析失败,则默认不做限制,长度判断值设置为整数最大值
                    int  length = 0;
                    length = Int32.TryParse(((item["LengthConstraint"])) ? "" : item["LengthConstraint"].ToString(), out length) ? length : Int32.MaxValue;

注意:System.DBNull 和 null 是不一样的,两者用 == 或者 equals 判断返回的是 false。

如果是这样,则将字段值追加到标签中的字符串输出

参考链接: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;
}

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
php与c++openssl加密通信发布时间:2022-07-13
下一篇:
不可或缺 Windows Native (22) - C++: 多重继承, 虚基类发布时间:2022-07-13
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap