Jak chętnie ładować skojarzenia bez powielania w NHibernate?

Muszę załadować listę bardzo dużych obiektów z tak wieloma dziećmi i dziećmi dzieci. jakie jest najlepsze podejście?

Używam bazy danych Oracle 11g i napisałem poniższą metodę, ale powoduje ona powstanie produktu kartezjańskiego (powielone wyniki):

 public IList<ARNomination> GetByEventId(long eventId)
        {
            var session = this._sessionFactory.Session;

            var nominationQuery = session.Query<ARNomination>().Where(n => n.Event.Id == eventId);

            using (var trans = session.Transaction)
            {
                trans.Begin();

                // this will load the Contacts in one statement
                nominationQuery
                    .FetchMany(n => n.Contacts)
                    .ToFuture();

                // this will load the CustomAttributes in one statement
                nominationQuery
                    .FetchMany(n => n.CustomAttributes)
                    .ToFuture();

                // this will load the nominations but joins those two tables in one statement which results in cartesian product
                nominationQuery
                    .FetchMany(n => n.CustomAttributes)
                    .FetchMany(n => n.Contacts)
                    .ToFuture();

                trans.Commit();
            }

            return nominationQuery.ToList();
        }

questionAnswers(2)

yourAnswerToTheQuestion