gpt4 book ai didi

javascript - 如何在Breezejs中查询和扩展多态导航集合属性

转载 作者:行者123 更新时间:2023-11-30 17:32:03 25 4
gpt4 key购买 nike

我们是第一次在现实世界的应用程序中使用 Breeze,它是一个很棒的框架。我们遇到了继承问题,因为当查询具有多态导航集合的实体时,我们可以在 JSON 中看到派生类型返回的数据,但该集合不会填充到客户端的 Breeze 实体中。我们在服务器上有 C# 类, Entity Framework 使用 Table-Per-Type 策略持久保存到数据库中。有一个名为 Client 的基本抽象类,SpecialClient 继承自它:

    public abstract class Client
{
public int Id { get; set; }
public int QuoteID { get; set; } //Foreign Key for navigation

public string FirstName { get; set; }
public string FamilyName { get; set; }
}

public class SpecialClient : Client
{
public decimal Income { get; set; }
public string ClientType { get; set; }
}

然后我们有一个名为 Quote 的父类,它具有基本 Client 的集合导航属性:

public class Quote
{
public Quote()
{
Clients = new List<Client>();
}

public int Id { get; set; }
public string Reference { get; set; }
public string Comments { get; set; }
public DateTime EffectiveDate { get; set; }

public List<Client> Clients { get; set; }
}

(我们已将主键/外键属性移至分部类,但为简洁起见,在此处将它们显示在相同的类中,不确定分部是否会导致问题?)

然后,我们尝试了客户端 Breeze 查询来检索报价并扩展 Clients 属性(我们有一个 Web API Breeze Controller,它使用包含 EF 上下文和 Breeze ContextProvider 的存储库进行正常的报价操作):

    [HttpGet]
public IQueryable<Quote> Quotes()
{
return _repository.Quotes();
}

和 Breeze 查询:

var query = breeze.EntityQuery.from('Quotes').expand('Clients');

查看返回的实体时,我们有一个 Quote 实体,但 Clients 数组尚未填充任何 Client 实体。我们检查了元数据,它看起来不错,它知道基本类型和派生类型,我们检查了我们在 Quote 和 Client 之间映射了一个外键,这也反射(reflect)在元数据中。我们还检查了查询生成的 JSON,同样,一切看起来都很好,Clients 导航集合填充在 Quote 实体上。当查询返回数据时,Breeze 似乎不会填充实体。

我们尝试删除从 Client 继承的 SpecialClient 类,然后这起作用了,因为我们得到了一个填充了基本客户端实体的集合,所以它看起来确实与继承有关。我们还尝试查看是否可以查询派生的 SpecialClient,但我们似乎无法弄清楚如何在使用谓词指定基类型的导航属性中查询派生类型:

var pred = new breeze.Predicate("Clients", "any", "clientType", "==", 'Life1'));

我们不确定如何指定我们要查询 SpecialClient 派生类型。当我们尝试上述操作时,Breeze 提示 Client 没有 clientType 属性。

如果有人可以就如何处理这种类型的继承查询和扩展问题以及我们哪里出了问题或者这是一个错误(未扩展部分)提出建议,我们将不胜感激。我们使用的是 Web API 2 (5.0.1)、Breeze(带 EF6 上下文提供程序)1.4.11,我们已检查所有客户端和服务器包都是 1.4.11。

我们如何指示 Breeze 我们在 Navigation 集合中有派生类型并且我们想要查询和检索它们?

非常感谢您的帮助!

编辑 1: 还应该提到,除了基本约定之外,我们没有使用任何特殊的 EF 映射。

最佳答案

通过查看 DocCode 示例,我们似乎已经解决了这个问题。事实证明,我们没有从基类 Client 返回到包含基类 Client 的导航集合的原理类 Quote 的引用导航:

public abstract class Client
{
public int Id { get; set; }
public int QuoteId { get; set; } //Foreign Key for navigation

public string FirstName { get; set; }
public string FamilyName { get; set; }

public Quote quote { get; set; } //Added this nav property back to Quote principle!
}

虽然我们有一个用于原则外键的 QuoteId 属性,但看起来我们还需要从基 Client 类返回对 Quote 的引用。我们现在可以使用 expand 进行查询,并且 Clients 集合中填充了派生类型。这是在 Breeze 中实现此类建模的正确方法吗?此外,在 Breeze 网站文档中添加一个关于继承的部分是否是个好主意,或者对于特定的后端 ORM 选择是否过于具体?

在相关说明中,是否可以对派生类型的属性进行查询限制(wheres 或谓词)?我们通过将查询推送到我们的服务器存储库并使用 OfType() 执行 LINQ Where 来获取我们想要限制的属性来解决这个问题,我们想知道 Breeze 是否可以在客户端执行此操作(我们看不到任何清楚的东西在文档中)。

感谢您的帮助,并继续与 Breeze 合作,我们非常喜欢这个框架!

关于javascript - 如何在Breezejs中查询和扩展多态导航集合属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22820899/

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