NHibernate QueryOver, как присоединиться к незаявленным отношениям

Как выполнить следующее объединение, чтобы вернуть пользователей, у которых есть доступ к компании с идентификатором компании. Проблема в том, что между UserAccess и User нет явной связи с использованием объекта User, они просто присоединяются к строковому свойству Username:

User(Username, Name)
UserAccess(Username, Company)
Company(Id)

Session.QueryOver<Company>()
        .Where(c => c.Id == companyId)
        .JoinQueryOver<UserCompanyAccess>(u => u.UserAccessList)
        .JoinQueryOver<User>(u => **Nope no property, just a string**

person jenson-button-event    schedule 16.08.2011    source источник
comment
См. также stackoverflow.com/questions/6378224/   -  person Ruben Bartelink    schedule 26.08.2015


Ответы (2)


можно сделать с помощью подзапроса

var subquery = QueryOver.Of<Company>()
    .Where(c => c.Id == companyId)
    .JoinQueryOver<UserCompanyAccess>(u => u.UserAccessList)
    .Select(uca => uca.UserName);

var users = session.QueryOver<User>()
    .WithSubquery.WhereProperty(u => u.Name).In(subquery)
    .List();
person Firo    schedule 16.08.2011

Начиная с 5.1.0, можно заставить hibernate генерировать фактическое соединение sql для необъявленных (неотображенных) отношений. Например. все заказы отсортированы по расходам клиента:

var criteria = _session
    .CreateCriteria<Order>("order");

criteria
    .CreateEntityAlias(
        "customer",
        Restrictions.EqProperty("order.customerId", "customer._id"),
        JoinType.LeftOuterJoin,
        typeof(Customer).FullName)
    .AddOrder(new Order("customer._lifetimeSpending", ascending:false));

return criteria.List<Order>();

Также возможно с QueryOver (пример из документов NHibernate):

Cat cat = null;
Cat joinedCat = null;

var uniquelyNamedCats = sess.QueryOver<Cat>(() => cat)
    .JoinEntityAlias(
        () => joinedCat,
        () => cat.Name == joinedCat.Name && cat.Id != joinedCat.Id,
        JoinType.LeftOuterJoin)
    .Where(() => joinedCat.Id == null)
    .List();
person Dmitry    schedule 09.10.2018