2

尝试删除数据库中的记录并随后使用 LINQ 重新创建它时,出现错误:无法添加已存在的实体。 虽然记录被删除。

我正在使用从方法SelectOrdersByOrderID(OrderID)中的 LINQ 查询中获得的数据初始化我的 Sales_header 对象 。

如果 Salesheader 的 OrderID 满足某个条件,我想删除数据库中的记录(Delete(Sales_header SalesHeader)),向对象添加附加值并在数据库中插入新记录(Insert(Sales_header SalesHeader))。

我不想更新记录,而是删除它并重新创建它。

Sales_header SalesHeader = new Sales_header();
SalesHeader = SalesHeaderClass.SelectOrdersByOrderID(OrderID) as Sales_header;


   if (SalesHeader.OrderID == *certain value*)
      {
       SalesHeaderClass.Delete(SalesHeader);
       SalesHeader.Orderdate = DateTime.Today;
       SalesHeader.Ordertime = DateTime.Now;
       SalesHeaderClass.Insert(SalesHeader);
      }
...

SalesHeaderClass 中通过 LINQ 选择 SalesHeader 的方法

public static object SelectOrdersByOrderID(int OrderID)
{
    var Query = (from p in dc.Sales_headers
                 where p.OrderID.Equals(OrderID)
                 select p).SingleOrDefault();
    return Query;

SalesHeaderClass 中通过 LINQ 插入 SalesHeader 的方法

public static void Insert(Sales_header SalesHeader)
      {
       dc.Sales_headers.InsertOnSubmit(SalesHeader);
       dc.SubmitChanges();
      }

SalesHeaderClass 中的方法通过 LINQ 删除 SalesHeader

public static void Delete(Sales_header SalesHeader)
      {
       var DelOrder = (from p in dc.Sales_headers
                       where p.OrderID == SalesHeader.OrderID
                       select p).Single();
       dc.Sales_headers.DeleteOnSubmit(DelOrder);
       dc.SubmitChanges();
      }

我必须做什么才能插入记录?创建具有相同值的新对象无济于事。

4

2 回答 2

0

除了为什么更新不适合的问题。

您需要两个上下文来首先删除记录,然后插入记录。EF 将所有插入/更新/删除操作保留在内存中,直到您执行 SubmitChanges(),因此您不能拥有两个具有相同 ID 的实体。

但是要将整个事情作为单个事务执行,您将需要一个TransactionScope

using (var scope = new TransactionScope()) {
    using (var salesHeader SalesHeader = new Sales_header()) {
        // Delete record
        ...
        salesHeader.SubmitChanges();
    }
    using (var salesHeader SalesHeader = new Sales_header()) {
        // Insert record
        ...
        salesHeader.SubmitChanges();
    }

    // Mark transaction complete
    scope.Complete();
}
于 2012-08-20T13:29:23.400 回答
0

要解决此问题,请使用不同的数据上下文进行删除和插入操作。

于 2012-09-05T07:35:11.917 回答