NHibernate: Критерии - получение списка идентификаторов детей

У меня есть пара сущностей в отношениях многих ко многим. Учитывая идентификатор родителя, как мне, используя ICriteria, получить список детей?

Код до сих пор:

var driverList = DriverGroup.CreateCriteria()
    .Add(Restrictions.IdEq(groupId))
    .SetFetchMode("Drivers", FetchMode.Eager)
    .SetResultTransformer(Transformers.DistinctRootEntity)
    .UniqueResult<DriverGroup>().Drivers.Select(x => x.Id).
    ToArray();

var criteria = Driver.CreateCriteria()
    .Add(Restrictions.In("Id", driverList));

Тем не менее, сгенерированный SQL:

SELECT
    this_.groupId as groupId5_1_,
    this_.name as name5_1_,
    this_.type as type5_1_,
    drivers2_.groupId as groupId3_,
    ... fields snipped ...
    drivers3_.userId as ID3,
    ... fields snipped ...
FROM
    dbo.Groups this_ 
left outer join
    dbo.Object_Rel drivers2_ 
        on this_.groupId=drivers2_.groupId
left outer join
    dbo.vwDriverSimple driverbase3_ 
        on drivers2_.ID=driverbase3_.userID 
WHERE
    this_.type=0 AND this_.groupId = @p0;
@p0 = 443 [Type: Int32 (0)]


SELECT
    this_.userID as userID10_1_,
    ... fields snipped ...
FROM
    dbo.drivers this_ 
WHERE
    this_.userID in (
        @p0, ... lots of parameters ...);

Как мне получить это, чтобы сгенерировать следующее?

SELECT
    this_.userID as userID10_1_,
    ... fields snipped ...
FROM
    dbo.drivers this_ 
WHERE
    this_.userID in (
        SELECT
            drivers3_.userId as ID3
        FROM
            dbo.Groups this_ 
        left outer join
            dbo.Object_Rel drivers2_ 
                on this_.groupId=drivers2_.groupId
        left outer join
            dbo.vwDriverSimple driverbase3_ 
                on drivers2_.ID=driverbase3_.userID 
        WHERE
            this_.type=0 AND this_.groupId = @p0;
        @p0 = 443 [Type: Int32 (0)]
);

1 ответ

Легко, запрос на ребенка напрямую.

IList<Driver> driverList = Drivers.CreateCriteria()
    .Add(Restrictions.Eq("Group.Id", groupId)) <-- modify according to your domain mapping
    .SetProjection(Projections.Property("Id"))
    .SetResultTransformer(Transformers.DistinctRootEntity)
    .List<Driver>();
Другие вопросы по тегам