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