如何在 SavingChanges 时(更新期间)停止 WCF 数据服务获取数据

发布于 2024-11-07 12:58:09 字数 1191 浏览 4 评论 0原文

我正在尝试从 WCF 客户端更新实体,如下所示:

        Ctxt.MergeOption = MergeOption.NoTracking;
        var q = Ctxt.Customers.Where(p => p.MasterCustomerId == "JEFFERSON").Select(o => o);
        //DataServiceCollection<Customer> oCustomers = new DataServiceCollection<Customer>(q, TrackingMode.None);
        DataServiceCollection<Customer> oCustomers = new DataServiceCollection<Customer>(q);
        oCustomers[0].FirstName = "KEFFERSON";
        //Ctxt.SaveChanges(SaveChangesOptions.ReplaceOnUpdate);
        //ctxt.SaveChangesDefaultOptions = SaveChangesOptions.ReplaceOnUpdate;
        Ctxt.SaveChanges();

当我尝试保存修改后的实体时,它首先尝试使用选择查询(到数据库)加载该实体,然后向数据库发出更新语句。

就我而言,我只是想让实体直接在数据库中更新,而无需先获取它。我不介意它是否覆盖数据库中的数据

我在 WCF 服务中尝试了以下操作:

protected override EF.Model.DataModel.PersonifyEntities CreateDataSource()
{
    var ctxt = new EF.Model.DataModel.PersonifyEntities();
    ctxt.Customers.MergeOption = System.Data.Objects.MergeOption.NoTracking;
    ctxt.ContextOptions.ProxyCreationEnabled = false;
    ctxt.ContextOptions.LazyLoadingEnabled = false;
    return ctxt;
}

但是,没有运气。有人能帮我解决这个问题吗?

I am trying to update an entity from a WCF client as follows:

        Ctxt.MergeOption = MergeOption.NoTracking;
        var q = Ctxt.Customers.Where(p => p.MasterCustomerId == "JEFFERSON").Select(o => o);
        //DataServiceCollection<Customer> oCustomers = new DataServiceCollection<Customer>(q, TrackingMode.None);
        DataServiceCollection<Customer> oCustomers = new DataServiceCollection<Customer>(q);
        oCustomers[0].FirstName = "KEFFERSON";
        //Ctxt.SaveChanges(SaveChangesOptions.ReplaceOnUpdate);
        //ctxt.SaveChangesDefaultOptions = SaveChangesOptions.ReplaceOnUpdate;
        Ctxt.SaveChanges();

When I try to save the modified entity, it first tries to load that entity using a select query (to database) and then issues update statement to database.

In my case, I simply want to have the entity to be directly updated in the database without fetching it first. I don't mind if it overwrites the data in database

I tried the following at WCF service:

protected override EF.Model.DataModel.PersonifyEntities CreateDataSource()
{
    var ctxt = new EF.Model.DataModel.PersonifyEntities();
    ctxt.Customers.MergeOption = System.Data.Objects.MergeOption.NoTracking;
    ctxt.ContextOptions.ProxyCreationEnabled = false;
    ctxt.ContextOptions.LazyLoadingEnabled = false;
    return ctxt;
}

But, no luck. Can anyone help me on this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

她如夕阳 2024-11-14 12:58:09

对于 WCF DataServices,客户端只能更新它跟踪的实体。因此,它必须先将实体下载到客户端,然后才能进行任何更改并将其保存回来。这就是为什么您在更新之前看到提取(我假设这是您看到的针对该特定实体的第一次提取)。希望这有帮助。

For WCF DataServices, the client can only update entities that it tracks. So it has to have the entity downloaded in the client before it can make any changes and save it back. Thats why you see the fetch (I am assuming that this is the first fetch that you are seeing for that specific entity) before the update. Hope this helps.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文