当前位置: 首页 > news >正文

EF Code 并发控制

【悲观控制】

不推荐用,EF Core 没有封装悲观并发控制的使用,需要使用原生Sql来使用悲观并发控制

一般使用行锁、表锁等排他锁对资源进行锁定,同时只有一个使用者操作被锁定的资源

拿sql server举例,可以使用表所、或者行所解决并发问题,

行锁:只锁定特定的行,减少等待时间,提供并发性。

表锁:锁定整个表,适用于大量数据进行更新的情况。

查询数据时候加事务、sql中加锁

【乐观控制】

EF Core 内置的方法,在执行数据时加上特殊的条件(where 条件中加入旧值)

update table set data1='new' where Id=1 and data1='old'

当发生冲突时,EF Core感知到影响行数为0,EF Code会报错错误。

其中data1字段为并发修改令牌,需要在定义表结构时,将data属性用IsConcurrencyToken来申明

builder.Property(h=>h.data).IsConcurrencyToken()

RowVersion的用法:

当需要修改多个字段做好并发控制时,1个并发修改令牌无法满足需求时,需要用到新的方法/

sql server数据库中可以用一个byte[]类型的属性做并发令牌属性,用IsRowversion把整个属性申明为RowVersion类型,在每次更新或新增数据时,sql server会自动为这一属性列生成新值

http://www.lryc.cn/news/519869.html

相关文章:

  • ceph fs status 输出详解
  • FFmpeg Muxer HLS
  • 如何用SQL语句来查询表或索引的行存/列存存储方式|OceanBase 用户问题集锦
  • 回归预测 | MATLAB实GRU多输入单输出回归预测
  • 【OpenGL/Assimp】渲染模型、半透明材质与封装光源
  • pandas与sql对应关系【帮助sql使用者快速上手pandas】
  • Linux WEB漏洞
  • 音视频入门基础:RTP专题(2)——使用FFmpeg命令生成RTP流
  • 大语言模型预训练、微调、RLHF
  • vue3后台系统动态路由实现
  • 解决idea中无法拖动tab标签页的问题
  • WMS仓库管理系统,Vue前端开发,Java后端技术源码(源码学习)
  • 25/1/12 嵌入式笔记 学习esp32
  • 【NLP】ELMO、GPT、BERT、BART模型解读及对比分析
  • go语言学习(数组,切片,字符串)
  • PM 实战 - 智能药盒PRD + 市场规模分析
  • SQL刷题快速入门(二)
  • hive迁移后修复分区慢,怎么办?
  • 代码随想录算法训练营day27
  • python 代码使用 DeepXDE 库实现了一个求解二维非线性偏微分方程(PDE)的功能
  • 【Go】:深入解析 Go 1.24:新特性、改进与最佳实践
  • VUE3 一些常用的 npm 和 cnpm 命令,涵盖了修改源、清理缓存、修改 SSL 协议设置等内容。
  • 【SpringBoot】@Value 没有注入预期的值
  • 【STM32-学习笔记-6-】DMA
  • js实现一个可以自动重链的websocket客户端
  • 企业总部和分支通过GRE VPN互通
  • 油猴支持阿里云自动登陆插件
  • 【2024年华为OD机试】(C卷,100分)- 字符串筛选排序 (Java JS PythonC/C++)
  • iOS - runtime总结
  • 第33 章 - ES 实战篇 - MySQL 与 Elasticsearch 的一致性问题