实体框架更新失败

Sea*_*ean 6 entity-framework

我想更新EF中的一行:

Case newCase = new Case(...);
dbContext.Entry(newCase).State = EntityState.Modified;
dbContext.SaveChanges();
Run Code Online (Sandbox Code Playgroud)

更新时我有这样的消息:

数据库操作预计会影响1行,但实际上会影响0行.自加载实体以来,数据可能已被修改或删除

没有并发性,因为我在我的机器上使用db.

如果我转到SQL事件探查器以查看执行的查询,则条件为:

WHERE [Id] = @p0 AND [RowVersion] = @p14;
Run Code Online (Sandbox Code Playgroud)

在这种情况下,@p0是1并且@p14是NULL,就像我想要修改的记录一样.但是,如果我在删除RowVersion部分查询后在SQL Server中手动启动此查询,则会成功,更新1行.

可能是什么问题,我该如何解决?

编辑:

我试图在更新之前选择记录,但错误是一样的:

    IEnumerable<Case> cases = from c in dbContext.Cases where c.Id.ToString() == "1" select c;
    Case cs = cases.SingleOrDefault();
    dbContext.Entry(cs).State = EntityState.Modified;
    dbContext.SaveChanges();
Run Code Online (Sandbox Code Playgroud)

这是完整的错误:

EntityFramework.Core.dll中出现"Microsoft.Data.Entity.DbUpdateConcurrencyException"类型的异常,但未在用户代码中处理

附加信息:数据库操作预计会影响1行但实际影响0行.自加载实体以来,数据可能已被修改或删除.有关理解和处理乐观并发异常的信息,请参阅 http://go.microsoft.com/fwlink/?LinkId=527962.

这是来自Sql Profiler的查询:

exec sp_executesql N'SET NOCOUNT OFF;

UPDATE [Case]
    SET 
        [Closed] = @p1
      , [Comment] = @p2
      , [ContactComment] = @p3
      , [ContactId] = @p4
      , [CreatedBy] = @p5
      , [CreatedDateTime] = @p6
      , [Description] = @p7
      , [Email] = @p8
      , [LastModifiedBy] = @p9
      , [LastModifiedDateTime] = @p10
      , [OpenedDateTime] = @p11
      , [Phone] = @p12
      , [RowVersion] = @p13
      , [SlaConsumedTime] = @p15
      , [SlaSuspended] = @p16
      , [SlaTotalTime] = @p17
      , [Status] = @p18
      , [Title] = @p19
WHERE 
    [Id] = @p0
    AND [RowVersion] = @p14;

SELECT @@ROWCOUNT;',

N'@p0 int,@p1 bit,@p2 nvarchar(max) ,@p3 nvarchar(max) ,@p4 int,@p5 int,@p6 datetime2(7),
@p7 nvarchar(4000),@p8 nvarchar(4000),@p9 int,@p10 datetime2(7),@p11 datetime2(7),
@p12 nvarchar(max) ,@p13 varbinary(max) ,@p14 varbinary(max) ,@p15 time(7),@p16 bit,
@p17 time(7),@p18 int,@p19 nvarchar(4000)',
@p0=1,@p1=0,@p2=NULL,@p3=NULL,@p4=0,@p5=1,@p6='2015-09-23 09:07:55.7041023',@p7=N'y',
@p8=N't@f.f',@p9=1,@p10='2015-09-23 09:50:02.9934006',@p11='2015-09-23 09:07:55.6796028',
@p12=NULL,@p13=NULL,@p14=NULL,@p15='00:00:00',@p16=0,@p17='00:00:00',
@p18=0,@p19=N'y'
Run Code Online (Sandbox Code Playgroud)

Jan*_*ang 7

其因,主键Null的值的LinQ

Case newCase = new Case(...);
dbContext.Entry(newCase).State = EntityState.Modified;
dbContext.SaveChanges();
Run Code Online (Sandbox Code Playgroud)

检查您的对象,它是否通过 Primary Key Null。此例外通常仅由于此原因。


Ank*_*wat 5

您实体的主键字段意味着 ID 未设置。意味着它为零。当您尝试更新记录时,其 ID 键应具有设置 ID 的值,并且更新将起作用。你的更新代码没问题。

  • 没有设置 id,正如我所说,条件是 WHERE [Id] = p0 且 p0 = 1。 (3认同)