Я не могу избежать этого выбора N + 1 - PullRequest
1 голос
/ 14 октября 2011

У меня есть это отображение (оно пришло из adventureworks, так как я использовал его в демонстрационном приложении для автоматической коллекции страниц)

ModelMapper mapper = new ModelMapper(new SimpleModelInspector());

            mapper.Class<Contact>(
                k => { 
                    k.Id(i => i.ContactID, m => m.Generator(Generators.Native));
                    k.Schema("Person");
                } 
                );
            mapper.Class<Employee>(
                k => 
                {
                    k.Id(i => i.EmployeeID, m => m.Generator(Generators.Native));
                    k.Schema("HumanResources");
                    k.ManyToOne(c => c.Contact, m =>  m.Column("ContactID"));
                }
                );
            mapper.Class<SalesOrderHeader>(
                k =>
                {
                    k.Id(i => i.SalesOrderID,m=>m.Generator(Generators.Native));
                    k.Schema("Sales");
                    k.ManyToOne(c => c.SalesPerson, m => m.Column("SalesPersonID"));
                    k.ManyToOne(c => c.Contact, m => m.Column("ContactID"));
                }
                );

            var map = mapper.CompileMappingForAllExplicitlyAddedEntities();
            cfg.AddDeserializedMapping(map,string.Empty);

и следующий (ограниченный) запрос:

var list = NHHelper.Instance.CurrentSession.Query<SalesOrderHeader>()
                            .Fetch(k => k.Contact)
                            .Fetch(k => k.SalesPerson)
                            .Skip(first)
                            .Take(count)
                            .ToList();

Я не могу удалить выбранное N + 1, вызванное контактом сотрудника, как я могу это сделать?Также можно изменить отображение!

EDIT: я добавляю рабочее решение с помощью @ cremor

 var list = NHHelper.Instance.CurrentSession.Query<SalesOrderHeader>()
                            .Fetch(k => k.Contact)
                            .Fetch(k => k.SalesPerson).ThenFetch(k=>k.Contact)
                            .Skip(first)
                            .Take(count)
                            .ToList();

, чтобы избежать этой проблемы.

1 Ответ

4 голосов
/ 14 октября 2011

Добавление .ThenFetch(c => c.Contact) после .Fetch(k => k.SalesPerson) также должно извлечь Contact из Employee.

...