gpt4 book ai didi

linq - 无效的 CRM 2011 LINQ 查询 : "Invalid ' where' condition. 实体成员正在调用无效的属性或方法。”

转载 作者:行者123 更新时间:2023-12-04 07:39:36 27 4
gpt4 key购买 nike

我正在尝试执行此查询以检索特定实体类型的审计项目

public List<Audit> GetAuditChangesSince(DateTime since, string entityType)
{
return (from a in OrgContext.CreateQuery<Audit>()
where
a.ObjectId != null && a.ObjectId.LogicalName == entityType &&
a.CreatedOn > since
select a).ToList();
}

a.ObjectId != null && a.ObjectId.LogicalName == entityType && 子句引起问题。我知道 .Equals() 可能会导致问题(因此 ==),并且 LINQ 提供程序有以下限制:

子句的左侧必须是属性名,子句的右侧必须是值

左边是属性,右边是常数。 .ObjectId.LogicalName 是否导致问题?

最佳答案

因为审计实体不提供与特定记录相关的实体的逻辑名称/类型代码的基本属性,所以您可以在这里做的最好的事情是链接到您希望定位的实体(或多个实体)审计记录——即不检索所有记录。

此类场景的一般技术是,您可以使用半废话条件链接到相关实体,例如检查主键是否不为空。对于您的情况,仅链接就足够了。

提取与联系人关联的审计记录的示例:

from a in OrgContext.CreateQuery<Audit>()
join c in ContactSet on a.ObjectId.Id equals c.ContactId
where a.ObjectId != null && a.CreatedOn > since
select a

关于linq - 无效的 CRM 2011 LINQ 查询 : "Invalid ' where' condition. 实体成员正在调用无效的属性或方法。”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16708156/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com