0

私のプロジェクトでは、次のような基準を作成しようとしています。

ICriteria criteria = session.CreateCriteria(typeof(Orders), typeof(Orders).Name);

if (param != null)
{                       
    if (param[1] != "System")
    {
        for (int index = 0; index < param.Length - 1; index++)
        {
            if (!string.IsNullOrEmpty(param[index]))
            {                                
                criteria.Add(Expression.Eq(
                    "RealizationPoint", 
                    CommonUtils.GetNameRealizationPointById(param[index])));
            }
        }
    }
    if (param[1] != "System" && param2 != null && 
        !string.IsNullOrEmpty(param2[0]))
    {
        for (int index = 0; index < param2.Length - 1; index++)
        {
            if (!string.IsNullOrEmpty(param2[index]))
            {
                criteria.Add(Expression.Eq(
                    "RealizationPoint", 
                    CommonUtils.GetNameRealizationPointById(param2[index])));
            }
        }
     }
 }

para1、param2:string [] param1、string[]param2。式stayANDの間の結果、ORが必要です。

4

1 に答える 1

1

Restrictions.Disjunction()複数の式を OR およびRestrictions.Conjuctions()ANDとしてグループ化するために使用できます。

簡単な例:

var conjunction1 = Restrictions.Conjunction();
for (int index = 0; index < param.Length -1; index++)
{
    conjunction1.Add(Restrictions.Eq("RealizationPoint", param[index]));
}

var conjunction2 = Restrictions.Conjunction();
for (int index = 0; index < param2.Length -1; index++)
{
    conjunction2.Add(Restrictions.Eq("RealizationPoint", param2[index]));
}

criteria.Add(Restrictions.Disjunction().Add(conjunction1).Add(conjunction2));

// Or with Restrictions.Or()
// criteria.Add(Restrictions.Or(conjunction1, conjunction2));

この SO の質問で、より多くの情報と代替案を見つけることができます: Hibernate の OR ステートメントを作成する方法は?

于 2012-09-13T10:39:17.517 に答える