Kit*_*ttu 10 c# query-expressions dynamics-crm-2011
我正在使用Condition表达式,但我无法为a添加多个条件FilterExpression.任何人都可以帮忙吗?我在这里发布了我的源代码.
带过滤器的ConditionExpression:
// 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);
Run Code Online (Sandbox Code Playgroud)
// Filter2
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);
Run Code Online (Sandbox Code Playgroud)
Sta*_*eXV 23
不确定我是否正确理解你的问题.如果我做对了,你想构建一个像这样的层次表达式:
(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));
Run Code Online (Sandbox Code Playgroud)
另请参阅MSDN上的示例.
Kon*_*ten 12
这就是我正在使用的.出于某种原因,我发现它更清楚.这可能是因为我使用初始化器语法,所以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)
}
}
}
}
...
Run Code Online (Sandbox Code Playgroud)
小智 10
条件:
(A_logicalName AND B_LogicalName) OR (B_LogicalName AND C_LogicalName)
Run Code Online (Sandbox Code Playgroud)
也可以用这种方式表达:
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;
Run Code Online (Sandbox Code Playgroud)
可以在MSDN上找到更复杂的查询.
| 归档时间: |
|
| 查看次数: |
34454 次 |
| 最近记录: |