首页 > 解决方案 > 如何使用刚刚创建的用户记录的 id 设置查找字段?

问题描述

我得到了error - no service provision,请有经验的人帮助我。

    var clinic = new new_clinic();
            clinic.new_name = "Medinet";

            Account trust = new Account();
            trust.Name = "bIRMINGHAM CITY hOSPITAL";
            Guid trustID = (Guid)Service().Create(trust);

            CrmEntityReference clinic_trust = new CrmEntityReference(trust.LogicalName, trustID);
            clinic.new_Trust = clinic_trust;
            clinic.new_ClinicDate = DateTime.Now;

            new_hospital hospital = new new_hospital();
            hospital.new_name = "Geek-guru";
            Service().Create(hospital);
            Guid hospitalID = (Guid)hospital.Id;
            clinic.new_HostingHospital = new CrmEntityReference(hospital.LogicalName, hospitalID);

            clinic.new_ClinicDate = new DateTime(2018, 07, 28);

            new_serviceprovision ser_contract = new new_serviceprovision();
            ser_contract.new_Trust = clinic_trust;
            ser_contract.new_Specialty = new OptionSetValue(100000018);
            Service().Create(ser_contract);
            Guid ser_con_id = (Guid)ser_contract.Id;
            clinic.new_ServiceContract = new CrmEntityReference(ser_contract.LogicalName, ser_con_id);

            // Account account =  (Account)GetOrgService().Retrieve(trust.LogicalName, trustID, new Microsoft.Xrm.Sdk.Query.ColumnSet("name"));

            //retreive the default business unit needed to create the user
            QueryExpression businessUnitQuery = new QueryExpression
            {
                EntityName = BusinessUnit.EntityLogicalName,
                ColumnSet = new ColumnSet("businessunitid"),
                Criteria = { Conditions = { new ConditionExpression("parentbusinessunitid", ConditionOperator.Null) } }
            };

            BusinessUnit businessUnit = Service().RetrieveMultiple(businessUnitQuery).Entities[0].ToEntity<BusinessUnit>();



            //creating a user
            SystemUser systemUser = new SystemUser();
            systemUser.DomainName = "" + "Chika";
            systemUser.FirstName = "Olabajo";
            systemUser.LastName = "Boss";
            systemUser.InternalEMailAddress = "onyebuchi@gmail.com";
            systemUser.BusinessUnitId = new EntityReference(BusinessUnit.EntityLogicalName, businessUnit.Id);
            Guid systemID = (Guid)Service().Create(systemUser);

           // systemUser = (SystemUser)Service().Retrieve(systemUser.LogicalName, systemID, new Microsoft.Xrm.Sdk.Query.ColumnSet("fullname"));

            //this field is a lookup field to User. Assigned to the user created above
            clinic.new_ClinicCoordinator = new CrmEntityReference(systemUser.LogicalName, systemID);

            clinic.new_BookedBy = new OptionSetValue(100000001);
            clinic.new_Type1 = new OptionSetValue(100000008);
            clinic.new_Type2 = new OptionSetValue(100000001);
            clinic.new_NumberofConsultants = 5;
            clinic.new_NumberofNursesSuppliedByTrust = 6;


            Service().Create(clinic);//getting error here
            MessageBox.Show("Sucessfully added a clinic record");

我已经在这几个星期了,我希望能得到一点帮助。我现在遇到“没有 serviceprivison 问题”,现在已经创建了一个用户,但仍然出现错误。

标签: c#dynamics-crmdynamics-crm-2011entity-relationship

解决方案


  1. 一步一步走。您有 3 件事接踵而至,例如创建用户、检索 FullName 列,然后更新clinic.new_ClinicCoordinator字段。注释掉这两个步骤并验证用户是否正在创建,如果创建成功然后检索下一个(这不是必需的,因为您已经拥有更新所需的 systemID)

  2. 使用 try catch 在代码中更好地处理异常

编辑:无法在代码中创建 CRM 在线交互式用户。阅读更多

更新:
合并下面的行,因为ser_contract对象没有用创建的 Guid 更新回来。做同样的事情hospitalID

Service().Create(ser_contract);
Guid ser_con_id = (Guid)ser_contract.Id;

这应该有效:

Guid ser_con_id = Service().Create(ser_contract);

推荐阅读