gpt4 book ai didi

c# - Wcf数据服务投影及查询方法

转载 作者:太空宇宙 更新时间:2023-11-03 16:01:36 25 4
gpt4 key购买 nike

我非常熟悉 RIA 服务,但不熟悉 WCF 数据服务,我想知道如何在后者中做一些我知道如何在前者中做的事情。

当数据服务由 Entity Framework (或类似的东西)支持时,我知道有关如何查询数据库实体的每种数据访问方法的示例。

但我经常想提供一种不直接基于任何数据库实体的可查询服务方法。它可以是多个数据库实体的组合、一个固有的分组,或者只是一个数据库实体以及一些额外的计算数据。

假设我有以下类(class):

// part of the model
class SomeEntity
{
public Guid Id { get; set; }
public String PropertyA { get; set; }
public String PropertyB { get; set; }

public Guid SubsidiaryKey { get; set; }
public virtual SomeSubsidiaryEntity Subsidiary { get; set; }
public virtual ICollection<SomeRelatedEntity> RelatedEntities { get; set; }
}

// part of the model
class SomeSubsidiaryEntity
{
public Guid Id { get; set; }
public String PropertyS { get; set; }
}

// not part of the model, exists only for the service layer
class SomeEntityProjection
{
public Guid Id { get; set; }
public String PropertyA { get; set; }
public String PropertyB { get; set; }
public String PropertyS { get; set; }
public Int32 RelatedEntitiesCount { get; set; }
}

前两个是服务使用的数据库模型的一部分,最后一个是投影实体。

投影实体不是数据库的一部分 - 它只存在于服务层。

有了 RIA 服务,我现在可以编写这样的查询函数:

public IQueryable<SomeEntityProjection> GetSomeEntitiesWithSomeFluff()
{
return
from e in this.DbContext.SomeEntities
select new SomeEntityProjection()
{
PropertyA = e.PropertyA,
PropertyB = e.PropertyB,
PropertyS = e.Subsidiary.PropertyS,
RelatedEntitiesCount = e.RelatedEntities.Count()
}
}

然后数据服务方法支持所有四个属性的客户端过滤和排序。所有此类客户端排序和过滤都将适本地委托(delegate)给数据库并在那里完成。

我找不到 WCF 数据服务的任何示例,所以我的问题是:这是否也适用于 WCF 数据服务?如果可以,该怎么做?

最佳答案

您将使用 Data Transfer Objects (DTO),它们与您的实体对象相似,但不一定相同。这样它们就可以独立变化。

关于c# - Wcf数据服务投影及查询方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21051184/

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