迭代NHibernate连接

时间:2009-06-10 21:17:33

标签: c# .net nhibernate join icriteria

这是我第一次将NHibernate用于一个大型项目,所以请耐心等待。基本上,我需要根据5个字段进行搜索。

我想在表格中显示结果。这是我写的一个测试,它基本上让所有拥有名为“DII”的员工进入Intients的客户端。当我运行它时,我得到一个错误,说某些Intakes是null。

var name = new Name("Alice", "B." "Cooper");
var staff = "DII";
var fileNumber = 12345;

var crit = NHibernateHelper.GetCurrentSession().CreateCriteria(typeof(Client));
var result = crit.CreateAlias("Intakes", "i");            
        .Add(Restrictions.Like("Name.First", name.First + "%"));
        .Add(Restrictions.Like("Name.Middle", name.Middle + "%"));
        .Add(Restrictions.Like("Name.Last", name.Last + "%"));   
        .Add(Restrictions.Eq("i.Staff", staff));            
        .Add(Restrictions.Eq("i.FileNumber", fileNumber));
        .List<Client>();

foreach (var client in result)
{
    Assert.IsTrue(client.Intakes.All(i => i.Staff == "DII");
}

但是,它确实返回了正确数量的客户端。我的问题是,我如何只迭代上述ICriteria生成的查询返回的相关Intakes?

我尝试将最后一行修改为:

Assert.IsTrue(c.Intakes.Where(i => i != null).All(i => i.Staff == "DII"));

它正常工作,除了生成的SQL是:

SELECT (Client + Intake Join) ...
SELECT FROM IntakeTable ...
SELECT FROM IntakeTable ...
SELECT FROM IntakeTable ...
(for each Intake that was returned with the join)

意味着它运行Join,然后再次获取所有Intakes,这不是我想要的。

1 个答案:

答案 0 :(得分:0)

多哈,想通了。这是因为我的映射。我正在使用:

<list ... />

...并按非位置列排序。因此我在Intakes协会中获得了一堆空条目。

我把它变成了一个有序的包,一切都按照你的预期运作。