当我尝试通过 lambda 扩展导航属性时,如下所示:
query = query.Expand(x => x.Dealers);
我的查询失败了
内部异常
内部异常消息:
表达式 'x => x.Dealers' 不是导航路径的有效表达式。lambda 表达式主体内唯一支持的操作是 MemberAccess 和 TypeAs。表达式必须至少包含一个 MemberAccess,并且不能以 TypeAs 结尾。
然而,当我尝试通过字符串参数进行扩展时:
query = query.Expand("Dealers");
一切似乎都正常工作。
我的“区域”微风客户端实体:
public class Region : BaseEntity
{
public Region();
public NavigationSet<Dealership> Dealers { get; set; }
public string Name { get; set; }
public Region Parent { get; set; }
public int? ParentId { get; set; }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
[Key]
public int RegionId { get; set; }
public string ShortName { get; set; }
public RegionType Type { get; set; }
}
我的经销商导航实体:
public class Dealership : BaseEntity
{
public Dealership();
public DateTime ActiveFrom { get; set; }
public DateTime? ActiveTo { get; set; }
public Brand Brand { get; set; }
[ForeignKey("Brand")]
public int BrandId { get; set; }
public string DealerCode { get; set; }
public DealerGroup DealerGroup { get; set; }
[ForeignKey("DealerGroup")]
public int? DealerGroupId { get; set; }
public virtual NavigationSet<DealerIR> DealerIRs { get; set; }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
[Key]
public int DealershipId { get; set; }
public bool IsActive { get; set; }
public string Line1 { get; set; }
public string Line2 { get; set; }
public string Line3 { get; set; }
public string Line4 { get; set; }
public string Line5 { get; set; }
public string Name { get; set; }
public string PostCode { get; set; }
public Region Region { get; set; }
[ForeignKey("Region")]
public int RegionId { get; set; }
}
我最近的尝试是通过“ForeignKey”数据注释使外键关系明确,但产生的错误仍然是一样的。
我正在使用微风锐利 v0.6.0.3。
更新1:这不是与上面完全相同的查询,而是相同的结果。只是我一直在逐步完成的 Breeze.Sharp 源代码的屏幕截图。大图在这里