巧用dynamic给对象字段动态赋值(经测试无效,使用反射解决)
动态把json对象的字段值赋给某个对象的字段
var dt=Utils.JsonDataTableConvert.ToDataTable(tableJson); foreach (DataRow row in dt.Rows) { var idNO = row["身份证号"]+""; var dbItem = dc.Set<User>().FirstOrDefault(ee=>ee.身份证号==idNO) as dynamic; if (dbItem==null) {//insert dbItem = new User(); foreach (var key in keys) { var val = row[item.Value[key]] + ""; //从json对象中取出 字段的值 //dbItem.UUId=val; //无意义,必须知道字段名UUId
//dbItem[key] = val; //把值赋给数据库查出的对象 会报错:无法将带 [] 的索引应用于“xx”类型的表达式,使用反射解决
MappingValue(dbItem,key,val); } } else {//update foreach (var key in keys) { var val =row[item.Value[key]] + ""; //dbItem[key] = val;无法将带 [] 的索引应用于“Tools.AA”类型的表达式
MappingValue(dbItem,key,val); } } dc.SaveChanges(); }
void MappingValue(User item, string _field, string value) { try { var type = item.GetType(); var field = type.GetProperty(_field); field.SetValue(item, value); } catch (Exception ex) { } }
08D12352-4044-490D-B3FD-978257103C13 From:http://www.cnblogs.com/xuejianxiyang/p/7678079.html
作者:xuejianxiyang
出处:http://xuejianxiyang.cnblogs.com
关于作者:Heaven helps those who help themselves.
本文版权归原作者和博客园共有,欢迎转载,但未经原作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。