通过 C# for CRM 2015 中的插件或简单控制台应用程序删除或删除日历规则“Time Off Rule”

Posted

技术标签:

【中文标题】通过 C# for CRM 2015 中的插件或简单控制台应用程序删除或删除日历规则“Time Off Rule”【英文标题】:Delete or Remove Calendar Rule "Time Off Rule" through a plugin or simple console application in C# for CRM 2015 【发布时间】:2016-09-27 21:59:32 【问题描述】:

我有以下问题:

我需要从属于“设备”的特定日历的日历规则中删除或移除“休假规则”。需要这样做,以便设备可用于服务日历上的计划。

不知怎的,我不明白该怎么做。

我能够检索需要删除的日历规则对象,但下一步我无法完成。

请告诉我:

    能否通过C#(SDK)实现

    执行类似操作的任何网络资源或代码部分。

下面的代码给了我错误

您尝试删除的对象与另一个对象相关联,并且 无法删除。

//equip is of Equipment type and is already initialized 
CrmEarlyBound.Calendar cal = (CrmEarlyBound.Calendar)svc.Retrieve("calendar", equip.CalendarId.Id, new ColumnSet(true));
Console.WriteLine("Got the user calendar");
List<CalendarRule> calendarRules = cal.CalendarRules.ToList();
Console.WriteLine("Got the calendar rules " +  cal.CalendarRules.ToList().Count);
foreach (CalendarRule cr in cal.CalendarRules)

   if (cr.Description == "Time Off Rule" && cr.StartTime.Value>=DateTime.Now)
   
       Console.WriteLine(cr.StartTime);
       Calendar calI = (Calendar)svc.Retrieve(cr.InnerCalendarId.LogicalName, cr.InnerCalendarId.Id, new ColumnSet(true));
       //svc.Delete(cr.InnerCalendarId.LogicalName, cr.InnerCalendarId.Id);
    
 

【问题讨论】:

【参考方案1】:

你快到了。必须删除 calendarrules 集合并更新 calendar 实体。

public static void ClearCalenderRules(IOrganizationService service, Guid bookableResourceId, DateTime startDate, DateTime endDate)

    using (var context = new CrmServiceContext(service))
    
        var bookableResource = context.BookableResourceSet.Where(b => b.Id == bookableResourceId).FirstOrDefault();

        if (bookableResource?.CalendarId != null)
        

            Entity entity = service.Retrieve("calendar", bookableResource.CalendarId.Id, new ColumnSet(true));
            EntityCollection entityCollection = (EntityCollection)entity.Attributes["calendarrules"];

            int num = 0;
            List<int> list = new List<int>();
            foreach (Entity current in entityCollection.Entities)
            
                DateTime dateTime2 = Convert.ToDateTime(current["starttime"]);
                if (dateTime2 >= startDate && dateTime2 <= endDate)
                
                    list.Add(num);
                

                num++;
            

            list.Sort();
            list.Reverse();

            for (int i = 0; i < list.Count; i++)
            
                entityCollection.Entities.Remove(entityCollection.Entities[list[i]]);
            

            entity.Attributes["calendarrules"] = entityCollection;
            service.Update(entity);
        
    
 

source

【讨论】:

以上是关于通过 C# for CRM 2015 中的插件或简单控制台应用程序删除或删除日历规则“Time Off Rule”的主要内容,如果未能解决你的问题,请参考以下文章

通过CRM API for 3CXPhone与其他应用进行对接

如何从crm中的插件注册中恢复我的插件数据?

如何通过 C# 中的 ListView for Windows 8 应用程序删除 SQLite 中的行

Dynamics CRM插件开发及调试

使用工作流 C# 向 CRM 365 中的所有联系人发送电子邮件生日?

Dynamics CRM - 如何通过 C# Plugin 给 Contact的 主键(FullName)赋值