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);
{
//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)
                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.
本文版权归原作者和博客园共有,欢迎转载,但未经原作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。