嘿那里,我试图在没有运气的情况下禁用我的收藏品上的LazyLoad ...到目前为止我尝试过的代码是:
// Person.cs
public class Person
{
public virtual int Id { get; private set; }
public virtual string FirstName { get; set; }
public virtual IList<Car> Cars { get; set; }
public Person()
{
Cars = new List<Car>();
}
public virtual void AddCar(Car car)
{
Cars.Add(car);
}
}
public class PersonMap : ClassMap<Person>
{
public PersonMap()
{
Id(x => x.Id);
Map(x => x.FirstName);
HasMany(x => x.Cars).KeyColumn("PersonId").Cascade.AllDeleteOrphan().Not.LazyLoad();
Table("Persons");
}
}
// Car.cs
public class Car
{
public virtual int Id { get; set; }
public virtual string CarName { get; set; }
public virtual Person Person { get; set; }
}
public class CarMap : ClassMap<Car>
{
public CarMap()
{
Id(x => x.Id);
Map(x => x.CarName);
HasOne(x => x.Person).Not.LazyLoad();
Table("Cars");
}
}
有什么建议吗?
提前致谢!
答案 0 :(得分:7)
延迟加载意味着只有在您访问cars属性时才会加载cars集合。因此,当您关闭此功能时,在装载一个人时,您将始终加载所有他的车。要查看这是否“有效”,您可以打开SQL事件探查器(或获取NHibernate profiler的试用版),然后调试代码。当您单步执行代码时,您可以看到汽车集合是否立即加载,或者只在您第一次访问时才会看到。
简而言之,我认为你做错了什么,只是误解了这个概念。
答案 1 :(得分:1)
如果您使用Load
方法,请尝试使用Get
。 Load
总是返回一个代理并加载懒惰的iirc。请注意SELECT N + 1。
编辑:重新阅读其他评论后,它可能会按预期工作。 Doron已经解释了延迟装载应该如何工作。因此,如果您不想将所有车辆与一个人一起加载,则应启用延迟加载。默认情况下已启用延迟加载,因为如果您急切地加载所有集合,则会产生SELECT N + 1,如前所述。也就是说,一个选择人,N选择汽车。这种行为通常是不可取的,因此我的警告:)延迟加载意味着只有在明确要求时才会加载集合。