【问题标题】:Wcf data service projections and query methodsWcf 数据服务投影和查询方法
【发布时间】:2014-01-10 17:57:40
【问题描述】:

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

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

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

假设我有以下课程:

// 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()
      }
}

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

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

【问题讨论】:

    标签: c# .net wcf wcf-data-services


    【解决方案1】:

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

    【讨论】:

    • 您可以说我的示例中的 SomeEntityProjection 就是这样一个 DTO。这仍然留下了如何使用 WCF 数据服务实际执行此操作的问题。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多