我得到以下表达式:

_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>

和用户类确实有它的映射文件中的电子邮件属性。我在做什么错了?

<强>更新,用户映射

    <?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的扩展方法。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top