CRM 插件 IQueryable 早期绑定实体子查询是“调用无效的属性或方法”

问题描述

我有一些使用 XrmToolBox 构建的早期实体,使用 IQueryable 数据集,尝试提取一些案例标题,其中案例未链接到另一个实体。尝试了这两种方法,它们产生了几乎相同的错误

if (cases.Where(x => !serviceContext.new_casegroupSet.Any(y => y.new_case.Id == x.IncidentId)).ToList().Count() > 0)
{
    throw new InvalidpluginExecutionException(OperationStatus.Canceled,$"Case/s missing Groups: \"{(cases.Where(x => !serviceContext.new_casegroupSet.Any(y => y.new_case.Id == x.IncidentId)).Select(x => x.Title).ToList())}\"");
}

if (cases.Where(x => serviceContext.new_casegroupSet.Where(y => y.new_case.Id == x.IncidentId).ToList().Count() == 0).ToList().Count() > 0)
{
    throw new InvalidpluginExecutionException(OperationStatus.Canceled,$"Case/s missing Groups: \"{(cases.Where(x => serviceContext.new_casegroupSet.Where(y => y.new_case.Id == x.IncidentId).ToList().Count() == 0).Select(x => x.Title).ToList())}\"");
}

错误是:Invalid 'where' condition. An entity member is invoking an invalid property or method.

我没有嵌套 Where() 或 Any() 的任何这些似乎工作正常,但 Any() 实际上似乎根本不起作用。

这甚至可能吗?或者我是否必须先获取案例并遍历它们以在链接实体中匹配?

解决方法

LINQ to CRM Provider 有很多限制,东西可以编译,但不能实际运行。我假设嵌套这些类型的语句就是其中之一。如果您想走那条路,我建议您尝试将它作为带有 Join 的普通 LINQ 语句运行。

就个人而言,在尝试 LINQ to CMR 几个月后,我放弃了它,何时尽可能使用 QueryExpressions,创建了一大堆扩展方法以使其更易于使用。您可以随意下载我的 nuget 库 DLaB.Xrm.Source。这简化了它们并消除了很多冗长的内容。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...