c# - 如何使用刚刚创建的用户记录的 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 问题”,现在已经创建了一个用户,但仍然出现错误。
解决方案
一步一步走。您有 3 件事接踵而至,例如创建用户、检索 FullName 列,然后更新
clinic.new_ClinicCoordinator
字段。注释掉这两个步骤并验证用户是否正在创建,如果创建成功然后检索下一个(这不是必需的,因为您已经拥有更新所需的 systemID)使用 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);
推荐阅读
- r - 计算曼哈顿距离和欧几里得距离
- version - 柯南自动增量数据包版本
- odoo-10 - 报告文档未在 PDF 中显示样式和标题,但它们是 HTML 版本(从 Odoo 8 迁移到 Odoo 10 后)
- svg - Svg 使用元素
- angular - 将项目从角度 4 升级到 6 后无法运行项目
- javascript - React 组件在按钮单击时自动关闭
- c# - c# Encog Framework,神经网络,为什么我在训练我的网络时会出现内部错误?
- php - 使用innerJoin 启动过多查询的学说
- postgresql - Ebean 不更新我的 postgreSQL 数据库
- javascript - Nuxt.js:意思是“不要忘记写在父组件(.vue 文件)里面”。