架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 697|回复: 0

[资料] EF 并发异常 DbUpdateConcurrencyException 重新查询返回缓存值

[复制链接]
发表于 2023-11-1 20:30:43 | 显示全部楼层 |阅读模式
需求:使用 EF 乐观锁来控制并发,如果遇到并发,增加重试机制,发现,重试后重新查询的数据为 EF 缓存数据,导致,一直保存异常。

The database operation was expected to affect 1 row(s), but actually affected 0 row(s); data may have been modified or deleted since entities were loaded. See http://go.microsoft.com/fwlink/?LinkId=527962 for information on understanding and handling optimistic concurrency exceptions.

讨论过后而引发对EF 6.x和EF Core查询缓存的思考:https://www.cnblogs.com/CreateMyself/p/8965216.html

处理并发Timestamp和ConcurrencyCheck区别
https://www.itsvse.com/thread-3616-1-1.html

如下图:

QQ截图20231101201104.jpg

SQL 脚本:

ASP.NET Core 6 后端代码:

控制器代码:



方案一(推荐)

使用 EntityState.Detached 将实体状态标记为不被上下文跟踪,修改如下:

如下图:

QQ截图20231101202508.jpg

方案二

调用 Reload() 方法刷新实体对象,代码如下:

虽然 reload 一样能实现刷新 EF 缓存值,但是,会造成多执行一次 SQL 查询,所以,并不推荐。

其它两种方式,AsNoTracking 不太合适,另外一种就没测试了。

(完)




上一篇:.NET 将数据库 varbinary 字符串转换成 byte[] 数组
下一篇:OpenWRT 设置开机启动执行命令
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-27 14:31

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表