是否可以在 NHibernate 中过滤特定的连接子类?
例如,我有以下课程:
Pet { Name }
Cat: Pet { Paws }
Budgie: Pet { Wings }
Person { Pets }
我想创建一个 NHibernate 搜索来给我有 4 只爪子的猫。
我似乎只能限制宠物的属性(名称)......
是否可以在 NHibernate 中过滤特定的连接子类?
例如,我有以下课程:
Pet { Name }
Cat: Pet { Paws }
Budgie: Pet { Wings }
Person { Pets }
我想创建一个 NHibernate 搜索来给我有 4 只爪子的猫。
我似乎只能限制宠物的属性(名称)......
你应该尝试这样的事情。不过还没有测试过,所以我不是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>();