Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/spring-boot/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Nhibernate 为什么我的IList<;T>;是否作为空对象列表返回?_Nhibernate_Nhibernate Mapping - Fatal编程技术网

Nhibernate 为什么我的IList<;T>;是否作为空对象列表返回?

Nhibernate 为什么我的IList<;T>;是否作为空对象列表返回?,nhibernate,nhibernate-mapping,Nhibernate,Nhibernate Mapping,虽然我意识到一套或一个包可能是正确的方式来做到这一点,我是新的NHibernate,我试图理解为什么会发生以下情况 我有两门课: public class Customer { public virtual int Id { get; protected set; } public virtual string CustomerName { get; set; } // Customer has many domains public virtual IList<Domai

虽然我意识到一套或一个包可能是正确的方式来做到这一点,我是新的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; }
}

如果我使用
这一切都很好。有人能解释一下引擎盖下发生了什么吗?

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

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

所以
应该只在每个
CustomerID有一个连续范围(比如0->10)且没有间隙的列的情况下使用?仅供参考,域表有53973行。好的……我最终发现对于列表,此列包含从零开始编号的顺序整数。如果必须处理遗留数据,请确保索引确实从零开始。在文档中。
<!-- 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>
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 */