小编典典

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

sql

我有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())。

此行为的原因是什么,以及如何解决或解决此问题?

谢谢。


阅读 230

收藏
2021-03-23

共1个答案

小编典典

是的,由于某种原因,Linq to SQL会将所有删除操作作为最后的操作。而且没有办法改变这一点。

也许有。我没有研究代码生成器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();
    }
2021-03-23