2

是否可以在 NHibernate 中过滤特定的连接子类?

例如,我有以下课程:

Pet { Name }
Cat: Pet { Paws }
Budgie: Pet { Wings }
Person { Pets }

我想创建一个 NHibernate 搜索来给我有 4 只爪子的猫。

我似乎只能限制宠物的属性(名称)......

4

1 回答 1

0

你应该尝试这样的事情。不过还没有测试过,所以我不是100%肯定。

 DetachedCriteria fetchCatsWith4Pawns = DetachedCriteria.For<Cat>();
 fetchCatsWith4Pawns.Add(Restrictions.Eq("Pawns", 4));
 fetchCatsWith4Pawns.SetProjection(Projections.Id());

 DetachedCriteria fetchPersonsWithCatsWith4Pawns = DetachedCriteria.For<Person>();
 fetchPersonsWithCatsWith4Pawns.CreateCriteria("Pets", "pet").Add(Subqueries.PropertyIn("pet.id", fetchCatsWith4Pawns));
 fetchPersonsWithCatsWith4Pawns.GetExecutableCriteria(session).List<Person>();
于 2009-11-19T10:50:41.937 回答