NHibernate Eager Загрузка с API Queryover для графа сложного объекта - PullRequest
7 голосов
/ 21 мая 2011

У меня есть довольно сложный граф объектов, который я хочу загрузить одним мах.

Образцы имеют дневники, которые имеют дневниковые тесты, которые имеют дневник Результаты

Daylog Tests имеют Testkeys, Daylog Results имеют Resultkeys и У TestKeys есть Resultkeys.

Я использую QueryOver API и Future, чтобы выполнить их как один запрос, и все данные, которые NHibernate должен создать экземпляр всего график возвращается, проверяется NHProf.

                public static IList<Daylog> DatablockLoad(Isession sess,
ICollection<int> ids)
                {
                        var daylogQuery = sess.QueryOver<Daylog>()
                                .WhereRestrictionOn(dl => dl.DaylogID).IsIn(ids.ToArray())
                                .Fetch(dl => dl.Tests).Eager
                                .TransformUsing(Transformers.DistinctRootEntity)
                                .Future<Daylog>();

                        sess.QueryOver<DaylogTest>()
                                .WhereRestrictionOn(dlt =>
dlt.Daylog.DaylogID).IsIn(ids.ToArray())
                                .Fetch(dlt => dlt.Results).Eager
                                .Inner.JoinQueryOver<TestKey>(dlt => dlt.TestKey)
                                .Fetch(dlt => dlt.TestKey).Eager
                                .Inner.JoinQueryOver<ResultKey>(tk => tk.Results)
                                .Fetch(dlt => dlt.TestKey.Results).Eager
                                .Future<DaylogTest>();

                        sess.QueryOver<DaylogResult>()
                                .Inner.JoinQueryOver(dlr => dlr.DaylogTest)
                                .WhereRestrictionOn(dlt =>
dlt.Daylog.DaylogID).IsIn(ids.ToArray())
                                .Fetch(dlr => dlr.ResultKey).Eager
                                .Fetch(dlr => dlr.History).Eager
                                .Future<DaylogResult>();

                        var daylogs = daylogQuery.ToList();

                        return daylogs;
                }

Тем не менее, я все еще получаю прокси для представления отношений между Testkey и ResultKey, хотя я специально загружаю эти отношения.

Я думаю, что весь этот запрос, вероятно, является представителем плохого понимание API QueryOver, поэтому я хотел бы любой совет на нем, но в первую очередь я хотел бы понять, почему я получаю прокси, а не список результатов, когда позже я пытаюсь получить daylogresult.resultkey.testkey.results.

Любая помощь?

Ответы [ 2 ]

5 голосов
/ 07 июля 2011

Ответом было вызвать NHibernateUtil.Initialize для различных объектов. Простое извлечение данных не означает, что NHibernate будет увлажнять все прокси.

0 голосов
/ 21 мая 2011

Вы должны загрузить все свои сущности в одном предложении QueryOver, чтобы избавиться от прокси. Но в этом случае в вашем запросе будет много объединений, поэтому я рекомендую использовать отложенную загрузку с пакетной обработкой.

...