![](/img/trans.png)
[英]Dynamics 365 (CRM) Version 9.1 online C# code Error: Entity Id must be the same as the value set in property bag
[英]Microsoft Dynamics CRM - Error message: Entity Id must be the same as the value set in property bag
您好StackOverflow社区,
我只是尝试复制“联系人”的记录 - 来自插件的实体或自定义工作流活动。 相关守则是
QueryExpression qe = new QueryExpression("contact")
{
ColumnSet = new ColumnSet("firstname", "lastname")
};
EntityCollection entityCollection = _organizationService.RetrieveMultiple(qe);
foreach (Entity entity in entityCollection.Entities)
{
entity.Id = Guid.NewGuid();
if (!entity.Attributes.Contains("firstname"))
{
entity.Attributes.Add("firstname", "");
}
entity["firstname"] = (entity.GetAttributeValue<string>("firstname") ?? "") + "(Copy)";
_organizationService.Create(entity);
}
不幸的是,我总是收到错误消息
“实体ID必须与属性包中设置的值相同”。
如果我遗漏了这条线
Entity.Id = Guid.NewGuid();
然后我收到了错误
“无法插入重复的密钥。”
我还尝试了各种其他方法来构建一个新的Guid,包括
byte [] bytes = new byte[16];
random.NextBytes(bytes);
entity.Id = new Guid(bytes);
要么
entity.Id = Guid.Empty;
结果也是
“实体ID必须与属性包中设置的值相同”。
另一方面,我有一个桌面应用程序,我借助本文https://msdn.microsoft.com/en-us/library/jj602970.aspx连接到我的Microsoft CRM 2016 Office 365系统并可以复制记录行。
任何帮助是极大的赞赏。
QueryExpression
总是返回id,作为实际的Entity.Id
,它的属性名称为contactid
。 这就是你得到错误的原因。 您可以删除此属性,但最佳做法是始终创建新的C#Contact对象,而不是更新从CRM中检索的对象。 此外,您不希望设置自己的GUID,因为CRM使用的序列GUID更适合索引和排序。
QueryExpression qe = new QueryExpression("contact")
{
ColumnSet = new ColumnSet("firstname", "lastname")
};
foreach (Entity entity in _organizationService.RetrieveMultiple(qe).Entities)
{
var copy = new Entity();
copy["firstname'] = (entity.GetAttributeValue<string>("firstname") ?? "") + "(Copy)";
_organizationService.Create(copy);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.