流利的NHibernate +禁用LazyLoad

时间:2011-01-20 21:23:13

标签: c# nhibernate fluent-nhibernate lazy-loading

嘿那里,我试图在没有运气的情况下禁用我的收藏品上的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");
    }
}

有什么建议吗?

提前致谢!

2 个答案:

答案 0 :(得分:7)

延迟加载意味着只有在您访问cars属性时才会加载cars集合。因此,当您关闭此功能时,在装载一个人时,您将始终加载所有他的车。要查看这是否“有效”,您可以打开SQL事件探查器(或获取NHibernate profiler的试用版),然后调试代码。当您单步执行代码时,您可以看到汽车集合是否立即加载,或者只在您第一次访问时才会看到。

简而言之,我认为你做错了什么,只是误解了这个概念。

答案 1 :(得分:1)

如果您使用Load方法,请尝试使用GetLoad总是返回一个代理并加载懒惰的iirc。请注意SELECT N + 1。

编辑:重新阅读其他评论后,它可能会按预期工作。 Doron已经解释了延迟装载应该如何工作。因此,如果您不想将所有车辆与一个人一起加载,则应启用延迟加载。默认情况下已启用延迟加载,因为如果您急切地加载所有集合,则会产生SELECT N + 1,如前所述。也就是说,一个选择人,N选择汽车。这种行为通常是不可取的,因此我的警告:)延迟加载意味着只有在明确要求时才会加载集合。