如何在不同线程中使用实体框架?

时间:2018-08-26 15:53:42

标签: c# database multithreading entity-framework

我有一个实体框架dbContext和方法,可以对数据库进行一些操作。如何从多个线程正确地调用它以避免死锁,连接错误等?我尝试了不同的方法,但有很多例外。

public void Foo(Bar bar)
{
    using (var db = new ApplicationDbContext())
    {
        db.Documents.Add(bar);
        ...
        db.SaveChanges();
    }
}

static void Main(string[] args)
{
    ...
    var t1 = new Thread(()=>Foo(bar1));
    thread.Start();

    var t2 = new Thread(()=>Foo(bar2));
    thread.Start();
    ...
}

我以前从未使用过线程。感谢您的帮助。

2 个答案:

答案 0 :(得分:3)

DbContext不是线程安全的,最好的方法是为每个工作单元(在您的情况下为每个线程)创建单独的DbContext实例。参见the recommendations

答案 1 :(得分:0)

创建一个数据库上下文并与其他线程共享,并在插入/更新/删除数据库中的记录时将其锁定。

您可以使用Factory之类的设计模式来创建DBContext的单个实例。

如果您尝试此解决方案而失败,请查看代码,也许您会错过解决方案的实现。