当我尝试映射嵌套的父子关系时,我遇到了FluentNHibernate的问题。 当我尝试这样的查询时:
var courier = session.Query<Courier>().FirstOrDefault(x => x.Code == "X");
CourierPrice中的DistributionCenter属性包含所有可能的信使的CourierPrice实体,而不仅仅是X.是否可以在不修改映射的情况下更改此行为?
public class Courier
{
public Courier()
{
Courierprices = new List<Courierprice>();
}
public virtual System.Guid Guid { get; set; }
public virtual string Code { get; set; }
public virtual IList<Courierprice> Courierprices { get; set; }}
}
public class Courierprice
{
public virtual System.Guid Guid { get; set; }
public virtual Courier Courier { get; set; }
public virtual Distributioncenter Distributioncenter { get; set; }
public virtual decimal? Price { get; set; }
}
public class Distributioncenter
{
public Distributioncenter()
{
Postcodes = new List<Postcode>();
}
public virtual System.Guid Guid { get; set; }
public virtual string Code { get; set; }
public virtual IList<Courierprice> Courierprices { get; set; }
}
映射:
public CourierMap()
{
Table("Couriers");
LazyLoad();
Id(x => x.Guid).GeneratedBy.Assigned().Column("Guid");
Map(x => x.Code).Column("Code");
HasMany(x => x.Courierprices).KeyColumn("Courier");
}
public CourierpriceMap()
{
Table("CourierPrices");
LazyLoad();
Id(x => x.Guid).GeneratedBy.Assigned().Column("Guid");
References(x => x.Courier).Column("Courier");
References(x => x.Distributioncenter).Column("DistributionCenter");
Map(x => x.Price).Column("Price");
}
public DistributioncenterMap()
{
Table("DistributionCenters");
LazyLoad();
Id(x => x.Guid).GeneratedBy.Assigned().Column("Guid");
Map(x => x.Code).Column("Code");
HasMany(x => x.Courierprices).KeyColumn("DistributionCenter");
}
答案 0 :(得分:1)
我用提供的映射制作了一个简单的应用程序,我发现它们有一个缺陷 在您使用的DistributioncenterMap中
Id(x => x.Guid).GeneratedBy.Assigned().Column("Guid");
而不是
Id(x => x.Guid).GeneratedBy.Guid().Column("Guid");
我在测试运行中添加了一些行,其中两行是Code ==“X”,它让我第一个没有问题。试一试
答案 1 :(得分:1)
查询返回正确的结果。 Distributioncenter.Courierprices集合应包含链接到Distributioncenter的所有Courierprices。