Свободный составной ключ Nhibernate, не создающий объединения для ссылочных объектов - PullRequest
2 голосов
/ 13 марта 2012

У меня есть сопоставление с составным ключом, как показано ниже:

CompositeId()
            .KeyReference(x => x.CreatedBy, "member_key")
            .KeyReference(x => x.Box, "box_key");

Это прекрасно работает для простых операций получения и вставки, однако это не создание соединений с таблицами, упомянутыми в справочнике, где я пытаюсь использовать их как часть запроса.

Итак, это:

return _sessionFactory.GetCurrentSession().QueryOver<BoxMember>()
            .Where(x => x.Box.Id == boxId)
            .Where(x => x.Member.DeletedDate == null)
            .Fetch(x => x.Box).Eager
            .Fetch(x => x.CreatedBy).Eager
            .List();

Создает следующий SQL:

    SELECT this_.member_key     as member1_5_0_,
       this_.box_key        as box2_5_0_
FROM   box_member this_
WHERE  this_.box_key = '2750e160-ba72-4a70-b554-9fd600e3cfd0' /* @p0 */
and    m1_.deleted_date is null;

1 Ответ

3 голосов
/ 12 июня 2012

У меня была точно такая же проблема.Добавление сопоставления ссылок помогло, но проблема все равно не имеет смысла:

Попробуйте это:

CompositeId() 
            .KeyReference(x => x.CreatedBy, "member_key") 
            .KeyReference(x => x.Box, "box_key"); 
Reference(x => x.CreatedBy);
Reference(x => x.Box);
...