NHibernate Eager загрузка многоуровневых дочерних объектов - PullRequest
24 голосов
/ 19 февраля 2009

У меня есть иерархия объектов, Порядок, Контакт, Адрес:

public class Order {
     public virtual Contact BillingContact { get; set; }
}

public class Contact {
     public virtual Address Address { get; set; }
}

Я хочу запросить заказ по идентификатору и хочу загрузить биллинг-контакт вместе с его адресом.

var criteria = DetachedCriteria.For<Order>()
     .SetFetchMode("BillingContact", FetchMode.Eager)

Этот критерий активно загружает BillingContact, но, разумеется, не адрес BillingContact. Если я добавлю:

     .SetFetchMode("BillingContact.Address", FetchMode.Eager)

Это не поможет.

Также обратите внимание, что эти отношения являются однонаправленными:

public OrderMap()
{
    References(x => x.BillingContact)
        .Not.Nullable()
        .Cascade.All();
}

public ContactMap()
{
    HasOne(x => x.Address)
        .Cascade.All()
        .FetchType.Join();
}

public AddressMap()
{
    Map(x => x.Address1);
} 

Как я могу построить объект критерия, который будет загружать дочерний элемент дочернего элемента? Эти сопоставления отношений кажутся правильными?

1 Ответ

26 голосов
/ 19 февраля 2009

Полагаю, вам может понадобиться добавить псевдоним в BillingContact, чтобы предоставить вам доступ к его адресу.

Что-то вроде:

var criteria = DetachedCriteria.For<Order>()
  .CreateAlias("BillingContact", "bc")
  .SetFetchMode("BillingContact", FetchMode.Eager)
  .SetFetchMode("bc.Address", FetchMode.Eager)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...