Почему мой IList <T>возвращается как список пустых объектов? - PullRequest
3 голосов
/ 29 декабря 2010

Хотя я понимаю, что набор или сумка, вероятно, являются правильным способом сделать это, я новичок в 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 пустых Domain объектов. 665384-й элемент в списке содержит действительный заполненный объект.

Только 63 Domain принадлежат этому клиенту, поэтому я предполагаю, что это какой-то декартово результат продукта. Я посмотрел на SQL в NHProfiler, но все, что я вижу, это запрос, который выглядит довольно невинным, когда я перебираю первый элемент в списке 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>, все это прекрасно работает. Кто-нибудь может объяснить, что происходит под капотом?

1 Ответ

2 голосов
/ 29 декабря 2010

При отображении списка индекс применяется к набору объектов в списке.То есть, если у Клиента есть набор из 63 Доменов, то обычно список будет содержать значения от 0 до 62, чтобы указать индекс объекта Домена в наборе Доменов этого Клиента.DomainId, первичный ключ таблицы, который наносит ущерб.Я предположил бы, что таблица Домена имеет всего 665384 строк (или меньше, если DomainId не начинается с 1 и имеет пробелы), но я думаю, что 63 будет действительным вместо одного.Вы проверили их все?: -)

...