如何解决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。这简化了它们并消除了很多冗长的内容。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。