Linq to Nhibernate странное поведение - PullRequest
2 голосов
/ 18 января 2012

У меня есть запрос заполнения таблицы, который должен получить все ссылки на сущности.

У меня есть клиент:

public class Client 
{
    public virtual int Id { get; set; }
    public virtual ICollection<Address> Addresses { get; protected set; }
    public virtual Address CurrentAddress { get; set; }
}

Адрес

public class Address 
{
   public virtual int Id { get; set; }
   public virtual string Address1 { get; set; }      
   public virtual string City { get; set; }
   public virtual string ZipCode { get; set; }
}

и схема БД:

enter image description here

Я хочу получить все адреса пользователей от Linq для Nhibernate:

ClientRepository.Where(x => x.Id == clientId).SelectMany(c => c.Addresses ).Where(x => x.Address1.Contains("Comp")).ToList();

Но я получил этот запрос:

SELECT TOP (20 /* @p0 */) Id31_,
                 Address2_31_,
                 Address3_31_,
                 City31_,                
                 ZipCode31_
FROM   (select address2_.Id                                    as Id31_,
               address2_.Address1                              as Address2_31_,
               address2_.Address2                              as Address3_31_,
               address2_.City                                  as City31_,               
               address2_.ZipCode                               as ZipCode31_,
               ROW_NUMBER() OVER( ORDER BY address2_.Address1) as __hibernate_sort_row
        from   CLIENTS client0_
               inner join AddressToClient addresshis1_
                 on client0_.Id = addresshis1_.ClientId
               inner join ADDRESSES address2_
                 on addresshis1_.AddressId = address2_.Id
        where  address2_.Id = 2 /* @p1 */) as query
WHERE  query.__hibernate_sort_row > 0 /* @p2 */
ORDER  BY query.__hibernate_sort_row

EDITED Мой репозиторий:

/// <summary>
/// Gets the repository query.
/// </summary>
/// <value>The repository query.</value>
protected override IQueryable<Client> RepositoryQuery
{
   get
   {
     return Session.Query<Client>();
   }
}

Где запросы фильтруются по id = address2_.Id, а не по идентификатору клиента.

Почему поиск происходит по адресу, а не клиенту?

1 Ответ

4 голосов
/ 18 января 2012

Попробуйте изменить одно из двух ваших «x» имен переменных на другое. В текущей версии выпуска NHibernate есть ошибка, которая может вызвать это.

...