分享 2 个 .NET EF 6 只更新某些字段的方法

前言

EF 更新数据时,通常情况下,是更新全部字段的,但实际业务中,更新全部字段的情况其实很少,一般都是修改其中某些字段,所以为了实现这个目标,很多程序员通常会这样作:

  1. 先从数据库中查询出实体对象,
  2. 然后修改其中某些字段字段的值,
  3. 最后再把整个实体对象的数据重新保存到数据库。

这样做性能很低,也不安全,那些不需要修改的字段的数据有可能这个过程中受到破坏。

其实有更好的作法的,本文抛砖引玉,分享 2 个 .NET EF 6 只更新某些字段的更好的方法。

代码

  1. 方法1: 更新数据不更新一些字段,留意注释

    c# 复制代码
    public void UpdateSomeField(int id)
    {
    	// 1. 先查询实体
    	var user = DbContent.t_user.Where(o => o.id == id).FirstOrDefault();
    	
    	// 2. 再修改字段的值
    	user.name = "周";
    	user.age = 1;
    	
    	// 3. age 属性不想修改,标记其 IsModified 属性 = false
    	// ---- 设置容器空间某一个模型的某一个字段 不提交到数据库
    	// ---- DbContent.Entry 是要更新到数据库的整个对象
    	
    	DbContent.Entry<t_user>(user).Property("age").IsModified = false;
    	
    	// 4. 更新数据
    	DbContent.SaveChanges();
    }
  2. 方法2: 直接添加模型更新,留意注释

    c# 复制代码
    public void UpdateSomeField(int id)
    {
    	// 1. 直接创建对象修改到数据库 不用先查询
    	t_user user = new t_user()
    	{
    		id = id,
    		name ="周",
    		age=1,
    
    	};
    	
    	// 2. 将实体对象加入 EF 对象容器中 获取容器对象
    	DbEntityEntry<t_user> entry = DbContent.Entry<t_user>(user);
    	
    	// 3. 容器对象状态设置为 unchanged
    	entry.State = System.Data.EntityState.Unchanged;
    	
    	// 4. 设置被改变的属性  是否要提交到数据库的字段
    	entry.Property(a => a.name).IsModified = true;
    	entry.Property(a => a.age).IsModified = true;
    	
    	// 5. 更新数据
    	DbContent.SaveChanges();
    }

总结

更新数据是实际业务中经常遇到的场景,可以进一步封装以上的方法,通过参数传递要修改或不修改的字段,提高 EF 6 的性能。你有更好的方法吗?欢迎分享讨论!

往期精彩

  1. 分享一个 .NET EF 6 扩展 Where 的方法
  2. 分享 .NET EF6 查询并返回树形结构数据的 2 个思路和具体实现方法
  3. 分享一个 .NET 通过监听器拦截 EF 消息写日志的详细例子
  4. 不会使用 EF Core 的 Code First 模式?来看看这篇文章,手把手地教你
  5. EF Core 性能很差?试试这 6 个小技巧
  6. 如何在 EF Core 中使用乐观并发控制
  7. EF Core 在实际开发中,如何分层?

我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊程序人生,共同学习,共同进步

相关推荐
2501_930707781 小时前
使用C#代码在 PowerPoint 中组合或取消组合形状
开发语言·c#
baivfhpwxf20239 小时前
c# 中对像之间频繁的转换会慢吗?
开发语言·c#
加号311 小时前
【C#】 实现 XRC 异或冗余校验:原理与实践
c#·xrc
小钻风336611 小时前
Java + Spring Boot 操作 Kafka 完整学习指南
c#·linq
叫我少年11 小时前
C# 程序的常规结构 — 命名空间、类型、入口点与表达式
c#
喵叔哟15 小时前
12.【.NET10 实战--孢子记账--产品智能化】--技术选型
.net
步步为营DotNet16 小时前
探秘.NET 11:C# 14 特性在后端性能优化中的深度应用
性能优化·c#·.net
Chris _data16 小时前
C# 与 PLC Modbus RTU 通信实践:从单例到线程安全的连接监控
开发语言·安全·c#
Chris _data16 小时前
C# WinForms 后台轮询 Modbus 数据与 UI 更新实践
开发语言·ui·c#
魔法阵维护师17 小时前
从零开发游戏需要学习的c#模块,第二十四章(场景管理 —— 标题、游戏、结束画面)
学习·游戏·c#