我正在使用Entity Framework 4自我跟踪实体模板(STE)和SQL Server CE。我看到一些非常奇怪的行为。如果我只是插入或更新,删除,一切都很好。但是,如果我插入一个对象然后更新它,那么当我执行更新时,将为该对象生成UPDATE
和INSERT
SQL语句(见下文)。
我正在使用存储库模式,我处理了存储库,并为每个调用包装了ObjectContext
,因此更新使用了新的ObjectContext
。另请注意,如果我重新启动服务器,对象的更新工作正常,所以只有我插入了一个对象。
由于我正在使用STE,因此更新会执行“通常”ApplyChanges
和SaveChanges
。
初始插入的跟踪是:
Creating ComputerEntities
--=============== BEGIN COMMAND ===============
declare @0 UniqueIdentifier set @0 = '2975bbbb-36a1-4c0a-8075-be273a96cd42'
declare @1 Bit set @1 = 'True'
declare @2 UniqueIdentifier set @2 = '2913bff8-9f2b-4965-8e02-5cb2a98f4498'
declare @3 Int set @3 = '2'
declare @4 Int set @4 = '1'
declare @5 NVarChar set @5 = 'test'
declare @6 NVarChar set @6 = 'C:\ProgramData\Kailana\ReVersion\Repositories\Projects\2975bbbb-36a1-4c0a-8075-be273a96cd42\2975bbbb-36a1-4c0a-8075-be273a96cd42'
insert [Repository]([Id], [Enabled], [ComputerId], [SQLVersionId], [ReleaseId], [Name], [Description], [DataSource], [Password], [DbUser], [DbUserPassword])
values (@0, @1, @2, @3, @4, @5, null, @6, null, null, null)
go
--=============== END COMMAND ===============
接下来我做了一个更新,这是生成的SQL:
Creating ComputerEntities
--=============== BEGIN COMMAND ===============
declare @0 Bit set @0 = 'True'
declare @1 UniqueIdentifier set @1 = '2913bff8-9f2b-4965-8e02-5cb2a98f4498'
declare @2 Int set @2 = '2'
declare @3 Int set @3 = '1'
declare @4 NVarChar set @4 = 'tested'
declare @5 NVarChar set @5 = 'C:\ProgramData\Kailana\ReVersion\Repositories\Projects\2975bbbb-36a1-4c0a-8075-be273a96cd42\2975bbbb-36a1-4c0a-8075-be273a96cd42'
declare @6 UniqueIdentifier set @6 = '2975bbbb-36a1-4c0a-8075-be273a96cd42'
update [Repository]
set [Enabled] = @0, [ComputerId] = @1, [SQLVersionId] = @2, [ReleaseId] = @3, [Name] = @4, [Description] = null, [DataSource] = @5, [Password] = null, [DbUser] = null, [DbUserPassword] = null
where ([Id] = @6)
go
-=============== END COMMAND ===============
--=============== BEGIN COMMAND ===============
declare @0 UniqueIdentifier set @0 = '2975bbbb-36a1-4c0a-8075-be273a96cd42'
declare @1 Bit set @1 = 'True'
declare @2 UniqueIdentifier set @2 = '2913bff8-9f2b-4965-8e02-5cb2a98f4498'
declare @3 Int set @3 = '2'
declare @4 Int set @4 = '1'
declare @5 NVarChar set @5 = 'test'
declare @6 NVarChar set @6 = 'C:\ProgramData\Kailana\ReVersion\Repositories\Projects\2975bbbb-36a1-4c0a-8075-be273a96cd42\2975bbbb-36a1-4c0a-8075-be273a96cd42'
insert [Repository]([Id], [Enabled], [ComputerId], [SQLVersionId], [ReleaseId], [Name], [Description], [DataSource], [Password], [DbUser], [DbUserPassword])
values (@0, @1, @2, @3, @4, @5, null, @6, null, null, null)
go
--=============== END COMMAND ===============
我已经用尽了所有关于造成这种情况的想法,所以任何想法都可以让我看到一个新的方向,我很感激。
谢谢, 瑞克
答案 0 :(得分:0)
成功插入后,尝试在您的实体上致电AcceptChanges
或MarkAsUnchanged
。