1
static Object LockEx=new Object();
public void SaveMyData(IEnumerable<MyData> list)
    {
        lock (LockEx)
        {
            using (PersistencyContext db = new PersistencyContext())
            {
                foreach (var el in list)
                {
                    try
                    {
                        db.MyData.Add(el);
                        db.SaveChanges();
                    }
                    catch (DbUpdateException)
                    {
                        db.Entry(el).State = EntityState.Modified;
                        db.SaveChanges();
                    }
                }
            }
        }

    }

从多个线程调用此方法。现在我使用静态锁来避免2个线程同时保存数据。虽然这是错误的,因为我只想保存数据。catch 用于创建更新查询,以防插入(添加)由于条目已存在而失败。

如果我删除锁会发生什么。工作将如何SaveChanges?我的代码应该是什么样子?谢谢

4

2 回答 2

2

我会删除锁,因为数据库已经通过设计处理并发,然后我还将在尝试添加记录之前验证记录是否存在,然后我会根据这个结果进行添加或更新。只是为了避免异常,因为它们是性能杀手。

于 2011-02-23T09:49:54.973 回答
1

基于 Davide 的回答,您还可以在添加所有新实体后调用 SaveChanges 一次。那应该更快。

于 2011-10-30T20:22:29.360 回答