【问题标题】:Multiple conditions for a FilterExpressionFilterExpression 的多个条件
【发布时间】:2012-12-28 09:30:24
【问题描述】:

我正在使用条件表达式,但我无法向FilterExpression 添加多个条件。 任何人都可以帮忙吗?我已经在这里发布了我的源代码。

带有过滤器的条件表达式:

  // Filter1
FilterExpression filter1 = new FilterExpression();
filter1.FilterOperator = LogicalOperator.And;
filter1.Conditions.Add(new ConditionExpression("A_LogicalName", ConditionOperator.Equal, id1));
filter1.Conditions.Add(new ConditionExpression("B_LogicalName", ConditionOperator.Equal, id2));
query.Criteria.Filters.Add(filter1);

// 过滤器2

FilterExpression filter2 = new FilterExpression();
filter2.FilterOperator = LogicalOperator.And;
filter2.Conditions.Add(new ConditionExpression("B_LogicalName", ConditionOperator.Equal, id3));
filter2.Conditions.Add(new ConditionExpression("C_LogicalName", ConditionOperator.Equal, id4));
q_ShoppingCartItemQuantityCheck.Criteria.Filters.Add(filter2);  

【问题讨论】:

  • 当涉及到更复杂的表达式时,我发现我很难像您那样设置它们。它是可行的,但不如初始化方法透明。当我在一小时后开始工作时,我将为您发布一个替代示例。希望它对您来说更具可扩展性。 (另外,你需要接受其中一个答案——我的答案当然是最好的,哈哈。)

标签: c# dynamics-crm-2011 query-expressions


【解决方案1】:

不确定我是否正确理解了您的问题。 如果我猜对了,你想构建一个这样的分层表达式:

(A_logicalName AND B_LogicalName) OR (B_LogicalName AND C_LogicalName)

对吗?

以下内容不能解决您的问题吗?

query.Criteria = new FilterExpression(); 
query.Criteria.FilterOperator = LogicalOperator.Or;

FilterExpression filter1 = query.Criteria.AddFilter(LogicalOperator.And);
filter1.Conditions.Add(new ConditionExpression("A_LogicalName", ConditionOperator.Equal, id1));
filter1.Conditions.Add(new ConditionExpression("B_LogicalName", ConditionOperator.Equal, id2));

FilterExpression filter2 = query.Criteria.AddFilter(LogicalOperator.And);
filter2.Conditions.Add(new ConditionExpression("B_LogicalName", ConditionOperator.Equal, id2));
filter2.Conditions.Add(new ConditionExpression("C_LogicalName", ConditionOperator.Equal, id3));

另请参阅MSDN 上的示例。

【讨论】:

  • 关于它的任何 Fluent 助手版本吗?
【解决方案2】:

这是我正在使用的。出于某种原因,我发现它更容易掌握。这可能是因为我使用初始化语法所以 YMMV。

...
Criteria = new FilterExpression
{
  FilterOperator = LogicalOperator.Or,
  Filters =
  {
    new FilterExpression
    {
      FilterOperator = LogicalOperator.And,
      Conditions =
      {
        new ConditionExpression("field1", ConditionOperator.NotNull),
        new ConditionExpression("field2", ConditionOperator.NotNull)
      }
    },
    new FilterExpression
    {
      FilterOperator = LogicalOperator.And,
      Conditions =
      {
        new ConditionExpression("field3", ConditionOperator.NotNull),
        new ConditionExpression("field4", ConditionOperator.NotNull)
      }
    }
  }
}
...

【讨论】:

  • 我发现它比我见过的其他任何东西都好
【解决方案3】:

条件:

(A_logicalName AND B_LogicalName) OR (B_LogicalName AND C_LogicalName)

也可以这样表达:

FilterExpression filter = new FilterExpression(LogicalOperator.Or);

FilterExpression filter1 = new FilterExpression(LogicalOperator.And);
filter1.Conditions.Add(new ConditionExpression("A_LogicalName", ConditionOperator.Equal, id1));
filter1.Conditions.Add(new ConditionExpression("B_LogicalName", ConditionOperator.Equal, id2));

FilterExpression filter2 = new FilterExpression(LogicalOperator.And);
filter2.Conditions.Add(new ConditionExpression("B_LogicalName", ConditionOperator.Equal, id2));
filter2.Conditions.Add(new ConditionExpression("C_LogicalName", ConditionOperator.Equal, id3));

filter.AddFilter(filter1);
filter.AddFilter(filter2);

query.Criteria = filter;

更复杂的查询可以在MSDN找到。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-04-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-11-24
    相关资源
    最近更新 更多