4

假设我有一个需要使用 nHibernate 呈现的 SQL 查询。SQL 查询的WHERE子句由三个OR语句组成,每个语句都包含一个条件列表。例如:

SELECT * 
FROM MyTable 
WHERE
    (OrderId = 1 and ItemId = 100) 
    OR
    (OrderId = 2 and ItemId = 200)
    OR
    (OrderId = 3 and ItemId = 300)

使用 nHibernate 的Criteria语法,我可以使用析取来实现:

var disjunction = Restrictions.Disjunction();

foreach (var tuple in OrdersAndLineItems)
{
    var conjunction = Restrictions.Conjunction();
    var order = tuple.Item1;
    var lineitem = tuple.Item2;

    conjunction.Add(Restrictions.Eq("OrderId", order.Id));
    conjunction.Add(Restrictions.Eq("LineItemId", lineitem.Id));

    disjunction.Add(conjunction);
}

var result = Session.CreateCriteria<SomeClass>().Add(disjunction).ToList();

我将如何使用 nHibernate 3.x 中的QueryOver语法编写相同类型的查询?

4

3 回答 3

1

至少在 NH 版本 3.0.0.4000 中有多个 Add 方法的重载。其中之一是具有可用于您的案例的通用参数,例如:

disjuction.Add<TypeinWhichPrimaryKeyPropertyExists>(x => x.PrimaryKey == 1)
于 2013-10-17T09:16:07.497 回答
0

对于要测试相等性的限制,请使用“Where”,例如:

Restrictions.Where<SomeClass>(x => x.OrderId == order.Id)
于 2013-09-12T14:16:01.747 回答
-3

没关系——我在发布后不久偶然发现了一篇较早的 StackOverflow 帖子,该帖子提供了我正在寻找的答案。这是我使用QueryOver语法重写的原始示例:

var disjunction = Restrictions.Disjunction();

foreach (var tuple in OrdersAndLineItems)
{
    var conjunction = Restrictions.Conjunction();
    var order = tuple.Item1;
    var lineitem = tuple.Item2;

    conjunction.Add(Restrictions.On<SomeClass>(x => x.OrderId).Equals(order.Id));
    conjunction.Add(Restrictions.On<SomeClass>(x => x.LineItemId).Equals(lineitem.Id));

    disjunction.Add(conjunction);
}

var result = Session.CreateCriteria<SomeClass>().Add(disjunction).ToList();
于 2012-12-12T10:45:46.040 回答