当前位置:  开发笔记 > 后端 > 正文

Linq to SQL:调用SubmitChanges()时的执行顺序

如何解决《LinqtoSQL:调用SubmitChanges()时的执行顺序》经验,为你挑选了1个好方法。

我有2个相关的数据库表,简化形式看起来像这样

Product(
  product_id,
  name
)

ProductSpecs(
  spec_id,
  product_id,
  name,
  value
)

外键通过product_id字段设置,ProductSpecs表对(product_id,name)对具有唯一约束.

现在在我的ASP.NET MVC应用程序中,当用户编辑产品规格并保存数据时,我删除了旧的规范并将所有规范作为新规格插入.

我首先调用DataContext.DeleteAllOnSubmit()并提供当前(旧)ProductSpecs作为参数,然后将新规范添加到Product.ProductSpecs集合中.

然后我调用DataContext.SubmitChanges()并得到一个错误,我的唯一约束被违反了.

通过查看DataContenxt.GetChangeText()返回的SQL语句,我可以看到INSERT在DELETE之前执行(即使我在Add之前调用了DeleteAllOnSubmit()).

这种行为的原因是什么以及如何修复或解决它?

谢谢.



1> Thomas Eyde..:

是的,出于某种原因,Linq to SQL执行所有删除操作是最后一件事.而且没有办法改变这一点.

或者也许有.我没有查看codegen DataContext,看看我们是否可以覆盖那里的东西.

您可以多次调用SubmitChanges().当我需要删除第一件事时,我的解决方法是标记我的删除,调用SubmitChanges(),然后执行插入和更新,再次调用SubmitChanges.

您可以将所有内容包装在TransactionScope中:

    var deletables =
        from toDelete in db.NamedValues
        where toDelete.Name == knownValue.Name
        select toDelete;

    using (var scope = new TransactionScope())
    {
        db.NamedValues.DeleteAllOnSubmit(deletables);
        db.SubmitChanges();

        db.NamedValues.InsertOnSubmit(knownValue);
        db.SubmitChanges();

        scope.Complete();
    }

推荐阅读
小色米虫_524
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有