Linq to Sql : 并发冲突及处理策略
1、 通过覆盖数据库值解决并发冲突
try { db.SubmitChanges(ConflictMode.ContinueOnConflict); //需要指定为ConflictMode.ContinueOnConflict } catch (ChangeConflictException e) { foreach (ObjectChangeConflict occ in db.ChangeConflicts) { occ.Resolve(RefreshMode.KeepCurrentValues); //保留当前值,覆盖数据库中的值 } }
2 、通过保留数据库值解决并发冲突
try { db.SubmitChanges(ConflictMode.ContinueOnConflict); } catch (ChangeConflictException e) { foreach (ObjectChangeConflict occ in db.ChangeConflicts) { occ.Resolve(RefreshMode.OverwriteCurrentValues);//以数据库中的值,重写当前值 } } db.SubmitChanges(ConflictMode.FailOnFirstConflict); //处理完冲突后,重试
3、通过与数据库值合并解决并发冲突
try { db.SubmitChanges(ConflictMode.ContinueOnConflict); } catch (ChangeConflictException e) { foreach (ObjectChangeConflict occ in db.ChangeConflicts) { occ.Resolve(RefreshMode.KeepChanges);//保留数据库中的值和当前值,进行合并处理 } } db.SubmitChanges(ConflictMode.FailOnFirstConflict); //处理完冲突后,重试
🐳 作者:dupeng0811 📢 版权:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接 💬 留言:同时 , 如果文中有什么错误,欢迎指出。以免更多的人被误导。 |
|