gpt4 book ai didi

c# - Entity Framework DbContext 和线程安全

转载 作者:太空狗 更新时间:2023-10-29 20:33:27 27 4
gpt4 key购买 nike

我需要在单个事务中更新我的数据库中的几个表,我读到使用 DbContext.SaveChanges 应该是这样做的方法。

不过,我还读到 DbContext 的生命周期应该尽可能短,因为它随着时间的推移加载更多实体而增长。

我还读到,为了使其成为线程安全的,每个操作都应该有自己的 DbContext

我是否应该为每个要更改的表设置一个 DbContext 并在每个 DbContext 上调用 SaveChanges?最后一个 SaveChanges 调用不会覆盖之前调用的更改吗?

最好的方法是什么? (我的网站需要这个)

最佳答案

Entity Framework is not thread-safe . An MVC controller is instantiated per request .因此,如果您对每个请求使用一个 DbContext,那么只要您不在 Controller 操作中手动生成线程(无论如何都不应该这样做),您就是安全的。

现在,如果您的应用程序中有并发性,例如多个用户外出访问可能用完的相同稀缺资源(如门票)的预订系统,您将必须实现逻辑围绕那个你自己。无论如何,线程安全都无法帮助您。

这就是为什么在评论中要求您提供代码的原因,因为一般解释线程安全的范围太广,可能不适用于您的情况。

关于c# - Entity Framework DbContext 和线程安全,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32411148/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com