Nhibernate и Линк проблема
Я получаю следующее выражение:
_senderRepos.Get(s => s.User.Email == fromAddress);
что приводит к
could not resolve property: User.Email of: Module.Fax2Pdf.MailToFax.Models.Sender
учебный класс:
public class Sender
{
public virtual int Id { get; set; }
public virtual Site Site { get; set; }
public virtual User User { get; set; }
}
отображение:
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" auto-import="true">
<class name="Module.Fax2Pdf.MailToFax.Models.Sender, Module.Fax2Pdf" table="fax_allowed_senders">
<id name="Id" column="id">
<generator class="sequence">
<param name="sequence">fax_allowed_senders_id_seq</param>
</generator>
</id>
<many-to-one column="site_id" name="Site" />
<many-to-one column="user_id" name="User" />
</class>
</hibernate-mapping>
А класс User имеет свойство Email в своем файле отображения. Что я делаю неправильно?
Обновление, сопоставление пользователей
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" auto-import="false">
<class name="Gate.Users.User, Gate.Models" table="users">
<id name="Id" column="id">
<generator class="sequence">
<param name="sequence">users_id_seq</param>
</generator>
</id>
<many-to-one column="site_id" name="Site" />
<property name="FirstName" column="first_name" type="String" length="30"/>
<property name="LastName" column="last_name" type="String" length="30"/>
<property name="CanDelete" column="can_delete" type="boolean" />
<property name="Email" column="email" type="String" length="255"/>
<property name="Department" column="department" type="String" length="30"/>
<property name="Title" column="title" type="String" length="30"/>
<many-to-one class="Gate.Extensions.Extension, Gate.Models" column="extension_id" name="Extension" />
<property name="Status" column="status" type="integer" />
<property name="CreatedAt" column="created_at" />
<property name="UpdatedAt" column="updated_at" />
<property name="TimeZone" column="timezone" type="integer" />
<property name="MiddleNames" column="middle_names" type="string" />
<property name="NamePrefix" column="name_prefix" type="string" />
<property name="NameSuffix" column="name_suffix" type="string" />
<property name="DateOfBirth" column="dob" />
<property name="RemovedAt" column="removed_at" />
<property name="ProxyMedia" column="proxy_media" type="boolean" />
</class>
</hibernate-mapping>
2 ответа
Решение
Извиняюсь. Я использовал QueryOver
на Get
метод в репозитории и Query
для всего остального. Это работает, когда я переключился на Query
,
Что делать, если вы позвонили .Expand()
на ваше IQueryable
первый?
Итак, если у вас была сессия, это может выглядеть так:
var senders =
(from sender in session.Query<Sender>().Expand("User")
where sender.User.Email == fromAddress
select sender);
К сожалению, для этого требуется импортировать метод расширения NHibernate.