我非常熟悉 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/