У меня есть сопоставление с составным ключом, как показано ниже:
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;