nhibernate - 为什么我的 IList<T> 作为空对象列表返回?

标签 nhibernate nhibernate-mapping

虽然我意识到 Set 或 Bag 可能是执行此操作的正确方法,但我是 NHibernate 的新手,我试图理解为什么会发生以下情况。

我有两个类:

public class Customer
{
  public virtual int Id { get; protected set; }
  public virtual string CustomerName { get; set; }
  // Customer has many domains
  public virtual IList<Domain> Domains { get; set; }
}

public class Domain
{
  public virtual int Id { get; protected set; }
  public virtual int CustomerID { get; set; }
  public virtual string DomainName { get; set; }
}

我的映射文件如下所示:

<!-- Domain -> tblDomains           -->           
<class name="Domain" table="tblDomains">

  <id name="Id">
    <column name="DomainID" sql-type="int" not-null="true"/>
    <generator class="identity"/>
  </id>

  <property name="CustomerID"/>
  <property name="DomainName"/>

</class>

<!-- Customer -> tblCustomer       -->
<class name="Customer" table="tblCustomer">

  <id name="Id">
    <column name="CustomerID" sql-type="int" not-null="true"/>
    <generator class="identity"/>
  </id>

  <property name="CustomerName" column="Customer"/>

  <list name="Domains">
    <key column="CustomerID"/>
    <index column="DomainID"/>
    <one-to-many class="Domain" />
  </list>

</class>

当我检索 Customer 时对象 Domains属性包含 665383 null Domain 的列表对象。列表中的第 665384 项包含有效的填充对象。

只有 63 Domain属于这个客户,所以我猜这是某种笛卡尔积结果。我已经查看了 NHProfiler 中的 SQL,但是当我遍历 Domains 中的第一项时,我所看到的只是一个看起来相当无辜的查询。列表:

SELECT domains0_.CustomerID  as CustomerID1_,
       domains0_.DomainID    as DomainID1_,
       domains0_.DomainID    as DomainID2_0_,
       domains0_.CustomerID  as CustomerID2_0_,
       domains0_.DomainName  as DomainName2_0_
FROM   tblDomains domains0_
WHERE  domains0_.CustomerID = 5667 /* @p0 */

如果我使用 <bag>这一切都很好。任何人都可以解释引擎盖下发生了什么吗?

最佳答案

对于列表映射,索引适用于列表中的对象集。也就是说,如果客户有一组 63 个域,那么通常该列表将包含从 0 到 62 的值,以指示域对象在该客户的域集中的索引。

您已将索引设置为表的主键 DomainId,这造成了严重破坏。我猜 Domain 表总共有 665384 行(如果 DomainId 不以 1 开头并且有间隙,则更少),但我认为 63 行而不是 1 行是有效的。你都检查了吗? :-)

关于nhibernate - 为什么我的 IList<T> 作为空对象列表返回?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4550676/

相关文章:

.net - 如何微调 FluentNHibernate 的自动映射器?

wcf - 带有 Web 应用程序的 Oracle Instant Client

c# - Nhibernate - 获取异常执行 SQL 查询

nhibernate - 多个表一对一

nhibernate-mapping - 如何在 NHibernate 3.2 mapping-by-code 中将整个映射设置为只读?

nhibernate - IndexOutOfRangeException 深入 NHibernate

java - 如何在 Hibernate 中映射一组枚举类型?

nHibernate 不检索手动更改的数据

c# - (流利的)NHibernate table-per-hierarchy; Id 仅与鉴别器一起唯一

.net - Fluent Nhibernate AutoMapping——同一张表的 2 个外键?