大家对将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 }
如有不足之处,欢迎指正