笔记:在Entity Framework Core中使用乐观并发控制来处理数据更新的冲突

一、目的:

在Entity Framework Core (EF Core) 中配置乐观并发控制主要涉及到使用并发令牌。并发令牌是在模型中定义的属性,用于在数据库操作期间检测并发冲突。当两个或更多用户尝试同时更新同一条记录时,EF Core 会使用这些令牌来确定是否有其他用户已经修改了数据。

二、实现

1. 定义并发令牌

你可以通过在实体类的属性上使用[ConcurrencyCheck]属性或使用Fluent API的.IsConcurrencyToken()方法来定义并发令牌。

cs 复制代码
using System.ComponentModel.DataAnnotations;

public class SomeEntity
{
    public int Id { get; set; }
    
    [ConcurrencyCheck]
    public string ConcurrencyToken { get; set; }
}
cs 复制代码
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    modelBuilder.Entity<SomeEntity>()
        .Property(e => e.ConcurrencyToken)
        .IsConcurrencyToken();
}

2. 处理并发冲突

当发生并发更新时,EF Core会抛出一个DbUpdateConcurrencyException异常。你需要捕获这个异常并根据你的业务逻辑处理冲突。处理并发冲突通常涉及到重新加载实体的最新版本,让用户决定如何解决冲突,或者自动重试更新。

cs 复制代码
try
{
    // 尝试保存更改到数据库
    context.SaveChanges();
}
catch (DbUpdateConcurrencyException ex)
{
    // 处理并发冲突
    // 例如,可以重新加载实体的最新状态
    foreach (var entry in ex.Entries)
    {
        var proposedValues = entry.CurrentValues;
        var databaseValues = entry.GetDatabaseValues();

        foreach (var property in proposedValues.Properties)
        {
            var proposedValue = proposedValues[property];
            var databaseValue = databaseValues[property];

            // TODO: 决定如何解决冲突
            // 例如,可以选择保留数据库的值或用户提出的值
        }

        // 更新原始值以匹配数据库的当前值
        entry.OriginalValues.SetValues(databaseValues);
    }

    // 重新尝试保存更改
    context.SaveChanges();
}

通过这种方式,EF Core 允许你灵活地处理并发更新,确保数据的一致性和完整性。

三、需要了解的知识点

ConcurrencyCheckAttributeConvention 类 (Microsoft.EntityFrameworkCore.Metadata.Conventions) | Microsoft Learn

乐观并发:概述 - ADO.NET | Microsoft Learn

Microsoft.EntityFrameworkCore 命名空间 | Microsoft Learn

System.Windows.Controls 命名空间 | Microsoft Learn

六、源码地址

GitHub - HeBianGu/WPF-ControlDemo: 示例

GitHub - HeBianGu/WPF-ControlBase: Wpf封装的自定义控件资源库

GitHub - HeBianGu/WPF-Control: WPF轻量控件和皮肤库

七、了解更多

System.Windows.Controls 命名空间 | Microsoft Learn

https://github.com/HeBianGu

HeBianGu的个人空间-HeBianGu个人主页-哔哩哔哩视频

相关推荐
lingggggaaaa10 小时前
小迪安全v2023学习笔记(八十二讲)—— Java组件安全&Solr&Shiro&Log4j&CVE复现
笔记·学习·安全
好望角雾眠10 小时前
第四阶段C#通讯开发-1:通讯基础理论,串口,通讯模式,单位转换,代码示例
开发语言·笔记·c#·串口·通讯
贝塔实验室11 小时前
两种常用的抗单粒子翻转动态刷新方法
论文阅读·经验分享·笔记·科技·学习·程序人生·fpga开发
范纹杉想快点毕业18 小时前
ZYNQ PS 端 UART 接收数据数据帧(初学者友好版)嵌入式编程 C语言 c++ 软件开发
c语言·笔记·stm32·单片机·嵌入式硬件·mcu·51单片机
茯苓gao21 小时前
STM32G4 电流环闭环
笔记·stm32·单片机·嵌入式硬件·学习
easy202021 小时前
机器学习的本质:从跑模型到真正解决问题
笔记·学习·机器学习
汇能感知1 天前
摄像头模组在智能家居设备中的应用
经验分享·笔记·科技
shizidushu1 天前
Graph RAG论文阅读笔记
论文阅读·笔记·graphrag
0_0梅伊阁诗人1 天前
Django ORM 模型
开发语言·数据库·笔记·python·oracle·django
m0_578267861 天前
从零开始的python学习(九)P142+P143+P144+P145+P146
笔记·python·学习