CRM 2011 后操作插件 - 尝试保存引用实体时,主实体不存在



我正在尝试为现场动态CRM 2011安装创建一个插件。

我已经注册了插件如下:

  • 消息:创建
  • 主要实体:联系人
  • 执行阶段:术后
  • 执行模式:同步
  • 执行顺序:1

插件代码如下:

public void Execute(IServiceProvider serviceProvider)
{
    var pluginExecContext = (IPluginExecutionContext)serviceProvider.GetService(typeof(IPluginExecutionContext));
    var orgServiceFactory = (IOrganizationServiceFactory)serviceProvider.GetService(typeof(IOrganizationServiceFactory));
    var orgService = orgServiceFactory.CreateOrganizationService(pluginExecContext.UserId);
    var orgServiceContext = new OrganizationServiceContext(orgService);
    var tracingService = (ITracingService)serviceProvider.GetService(typeof(ITracingService));
    if (pluginExecContext.InputParameters.Contains("Target") &&
            pluginExecContext.InputParameters["Target"] is Entity)
    {
        var target = (Entity)pluginExecContext.InputParameters["Target"];
        if (target.LogicalName != Contact.EntityLogicalName) 
            return;
        try
        {
            var customerServicesUser = orgServiceContext.CreateQuery(SystemUser.EntityLogicalName)
                .Where(x => (string)x["fullname"] == "Customer Services").FirstOrDefault();
            if (customerServicesUser == null)
                throw new InvalidPluginExecutionException("No Customer Services user exists.");
            var sendEmail = new cdi_sendemail
                {
                    cdi_fromrecordowner = false,
                    cdi_contactid = new EntityReference(Contact.EntityLogicalName, pluginExecContext.PrimaryEntityId),
                    cdi_fromid = new EntityReference(SystemUser.EntityLogicalName, customerServicesUser.Id)
                };
            tracingService.Trace("PostContactCreate plug-in: Creating the cdi_sendemail entity.");
            orgService.Create(sendEmail);
        }
        catch (FaultException<OrganizationServiceFault> ex)
        {
            throw new InvalidPluginExecutionException("An error occurred in the PostContactCreate plug-in.", ex);
        }
        catch (Exception ex)
        {
            tracingService.Trace("PostContactCreate plug-in: {0}", ex.ToString());
            throw;
        }
    }
}

当我使用插件注册工具分析插件并调试故障异常时,出现以下错误:

ID = abbc7e0a-20a0-e111-a36e-005056860004 的联系人不存在。

我有点理解为插件正在尚未提交的 SQL 事务中执行。CRM SDK 示例中的"FollowupPlugin"也创建了一个引用的实体,声明它需要异步注册,这也是有意义的,因为这允许 SQL 事务提交。

所以我想我的问题是,如何在同步插件中创建引用实体?

查看 SDK 示例以获取非常相似的示例 - 我认为您需要在沙盒中注册。

在创建消息上以异步模式为帐户实体注册此插件。或者,您可以在沙盒中的事后注册插件

最新更新