EF更新指定字段...
2016-07-25 17:21
323 查看
EF更新指定的字段(未改进版本)...
搜来搜去发现没有自己想要的啊...或许本来就有更好的办法来实现我这个,所以没有人来搞吧...
如果有,请不吝告知..GG..
//要更改UserInfo表中指定的列,比如这个表有15列,如果很多列都要更新,就要判断要更新哪个不要更新哪个.. //现在这样就是传过来多少列,循环更新下就可以了 public string UserInfo_Update_Test(string jsonParames) { jsonParames = "一个json串";//比如:{ "ID": "7","LoginName": "修改后的登录名","PassWord": "修改后的密码"} Dictionary<string, object> userInfoDic = (Dictionary<string, object>)JSON.Instance.Parse(jsonParames);//需要引用fastJSON程序集 int ID = 0; if (userInfoDic.ContainsKey("ID")) { int.TryParse(userInfoDic["ID"].ToString(), out ID); } var db = new DBEntities(); UserInfo info = db.UserInfo.Single(u => u.ID == ID); //本来想的是一个个字段来判断,if(userInfoDic.ContainsKey("要更新的字段")){info.要更新的字段 =userInfoDic["要更新的字段"]; } //由于UserInfo这个表字段较多...并且还有其他好多表要搞...所以用了下面的方法... #region 主要内容...用来替换太多的if判断... foreach (var pro in info.GetType().GetProperties()) { if (userInfoDic.ContainsKey(pro.Name)) { pro.SetValue(info, userInfoDic[pro.Name]); } } db.SaveChanges();//这个不能忘... #endregion return null; }
EF更新指定的字段(改进版本)...
先将给实体赋值的步骤封装为一个方法/// <summary> /// 用户更新的时候-entity是已经存在的值了 /// </summary> /// <typeparam name="TEntity"></typeparam> /// <param name="entity"></param> /// <param name="userInfoDic"></param> /// <returns></returns> public static TEntity setEntityValue<TEntity>(TEntity entity, Dictionary<string, Object> userInfoDic) where TEntity : class { //var entity = Activator.CreateInstance<TEntity>(); int tempInt = 0; DateTime tempDateTime = DateTime.Now; foreach (var pro in entity.GetType().GetProperties()) { //如果传来的参数中有 全部属性中的值,则开始赋值... //目的主要还是判断传来要更新的有哪些参数... if (userInfoDic.ContainsKey(pro.Name)) {//改进就是改进的这一部分,多出判断,要不然会报错! switch (pro.PropertyType.Name.ToLower()) { case "int32": //pro.SetValue(entity, userInfoDic[pro.Name].ToString());//测试代码... int.TryParse(userInfoDic[pro.Name].ToString(), out tempInt); pro.SetValue(entity, tempInt); break; case "string": pro.SetValue(entity, userInfoDic[pro.Name].ToString()); break; case "datetime": //tempDateTime = DateTime.ParseExact(key.Value.ToString(), "", System.Globalization.CultureInfo.InvariantCulture); pro.SetValue(entity, tempDateTime); break; default: pro.SetValue(entity, userInfoDic[pro.Name].ToString()); break; } } } return entity; }
调用↓
DBEntities entity = new DBEntities(); UserInfo info = entity.UserInfo.SingleOrDefault(u => u.ID == ID); if (info != null) { info = setEntityValue<UserInfo>(info, userInfoDic); int changeCount = entity.SaveChanges(); retJsonStr = "{\"ret\":\"1\",\"msg\":\"" + Common.Enums.enumOperator.Edit.ToString() + "成功!更新数目" + changeCount.ToString() + "\"}";//返回的json数据 }
x
相关文章推荐
- Snackbar的使用
- js限制文本框只能输入数字
- eclipse svn插件 links方式
- 博客积分规则 & 博客等级
- NSFileManager 沙盒存储
- 脑残用户登录代码调优
- mysql 踩过的坑
- 设计模式(十五) 命令模式
- PAT(Programming Ability Test)等级,可以基本对应程序能力
- 14A - Letter
- VS2015,1>cl : Command line error D8016: '/ZI' and '/Gy-' command-line options are incompatible
- 精模匹配地形
- Android中Thread和Service的区别zz
- myeclipse中的类恢复之前的版本方法
- ionic中的生命周期函数
- postgres 约束 多个条件 联合 约束
- iOS GCD 定时器
- LVS(Linux Virtual Server) 学习笔记
- C++ hdoj 2042 不容易系列二
- setPreferredSize()、getPreferredSize()与pack()的配合使用以及setSize()方法