zoukankan      html  css  js  c++  java
  • .net判断System.Data.DataRow中是否包含某列

    大家对将DataRow转成实体对象并不陌生,转成实体的时候一般都会加上这个判断  if (row["字段名"] != null && row["字段名"].ToString() != "") ,这个写法会存在一个问题,当row不存在这个字段时就会抛出异常,导致程序崩溃,这种情况在数据库频繁地修改出现的频率高,因为修改数据库时,代码里面转成实体的方法就不适用了,基于业务的不同可能存在多个转成实体的方法,这样修改数据库时,并修改代码的同时很容易遗漏修改,导致程序崩溃,特别是需求经常变动的项目(改数据库)。所以个人建议在判断里面加多一个逻辑条件:

     if (row.Table.Columns.Contains("字段名") && row["字段名"] != null && row["字段名"].ToString() != "")   //row.Table.Columns.Contains("字段名") 是判断row中是否存在该字段,存在返回true,否则返回 false

    这个逻辑条件可以避免当row不存在该字段是出现的错误。

    代码例子

    实体类:

    1     public class User
    2     {
    3         public int UserId { get; set; }
    4         public string UserName { get; set; }
    5         public int Age { set; get; }
    6     }

    转成实体类方法:

     1             User userModel=new User();
     2             if (row.Table.Columns.Contains("UserId") && row["UserId"] !=null && row["UserId"].ToString() !="")
     3             {
     4                 userModel.UserId = Convert.ToInt32(row["UserId"]);
     5             }
     6             if (row.Table.Columns.Contains("UserName") && row["UserName"] != null && row["UserName"].ToString() != "")
     7             {
     8                 userModel.UserId = Convert.ToInt32(row["UserName"]);
     9             }
    10             if (row.Table.Columns.Contains("Age") && row["Age"] != null && row["Age"].ToString() != "")
    11             {
    12                 userModel.UserId = Convert.ToInt32(row["Age"]);
    13             }
    14             return userModel;
    15         }

    如有不足之处,欢迎指正

  • 相关阅读:
    Running ROS on Windows 10
    Roomblock: a Platform for Learning ROS Navigation With Roomba, Raspberry Pi and RPLIDAR(转)
    Understand:高效代码静态分析神器详解(转)
    VMware下ubuntu与Windows实现文件共享的方法
    Install rapyuta client on Ubuntu14.04
    Install rapyuta client on Raspberry Pi
    Installing ROS Indigo on the Raspberry Pi
    Shrinking images on Linux
    How to emulate a Raspberry Pi on your PC
    Remastersys打包你自己的ubuntu成iso文件
  • 原文地址:https://www.cnblogs.com/linJie1930906722/p/6343185.html
Copyright © 2011-2022 走看看