.net判断System.Data.DataRow中是否包含某列

本文介绍了一种将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         }

如有不足之处,欢迎指正

转载于:https://www.cnblogs.com/linJie1930906722/p/6343185.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值