gpt4 book ai didi

WCF 数据服务 - 更新记录而不是插入记录

转载 作者:行者123 更新时间:2023-12-04 16:00:16 24 4
gpt4 key购买 nike

我正在开发一个带有自我跟踪实体的 WCF 数据服务,我想防止客户端插入重复的内容。每当他们在没有为数据键提供值的情况下 POST 数据时,我必须执行一些逻辑来确定该数据是否已经存在于我的数据库中。我写了一个这样的更改拦截器:

[ChangeInterceptor("MyEntity")]
public void OnChangeEntity(MyEntity item, UpdateOperations operations){
if (operations == UpdateOperations.Add)
{
// Here I search the database to see if a matching record exists.
// If a record is found, I'd like to use its ID and basically change an insertion
// into an update.
item.EntityID = existingEntityID;
item.MarkAsModified();
}
}

但是,这是行不通的。 existingEntityID 被忽略,因此,记录总是被插入,从不更新。甚至有可能做到吗?提前致谢。

最佳答案

万岁!我设法做到了。

item.EntityID = existingEntityID;
this.CurrentDataSource.ObjectStateManager.ChangeObjectState(item, EntityState.Modified);

我不得不在别处更改对象状态,即。通过调用 ObjectStateManager 的 .ChangeObjectState,它是底层 EntityContext 的一个属性。我被 .MarkAsModified() 方法误导了,在这一点上,我不确定它的作用。

关于WCF 数据服务 - 更新记录而不是插入记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5793533/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com