crm操作业务部门

本文介绍了一个用于操作CRM系统中业务部门的实用工具类,包括创建、更新部门信息,设置部门层级关系,以及添加或移除部门成员等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    using System;
    using System.Linq;
    using Microsoft.Xrm.Sdk;
    using Microsoft.Crm.Sdk.Messages;
    using System.Collections.Generic;
    using Microsoft.Xrm.Sdk.Messages;

    /// <summary>
    /// 操作业务部门
    /// </summary>
    public class BusinessUnitHelper
    {
        public static readonly string entityName = "businessunit";
        public Guid businessunitId = Guid.Empty;

        /// <summary>
        /// 创建业务部门
        /// </summary>
        public void CreateUnit(IOrganizationService service)
        {
            Entity en = new Entity() { LogicalName = entityName };
            en["name"] = "软件开发部";
            businessunitId = service.Create(en);
        }

        /// <summary>
        /// 修改业务部门
        /// </summary>
        public void UpdateUnit(IOrganizationService service)
        {
            Entity en = new Entity() { LogicalName = entityName,Id = businessunitId };
            en["name"] = "软件开发事业部";
            service.Update(en);
        }

        /// <summary>
        /// 设置业务部门的上级部门
        /// </summary>
        /// <param name="service">服务</param>
        /// <param name="parentId">上级业务部门id</param>
        public void SetParentBusinessUnit(IOrganizationService service,Guid parentId)
        {
            SetParentBusinessUnitRequest request = new SetParentBusinessUnitRequest();
            //当前业务部门id
            request.BusinessUnitId = businessunitId;
            //上级业务部门id
            request.ParentId = parentId;
            service.Execute(request);
        }
       
        /// <summary>
        /// 检索业务部门层次结构中的所有业务部门
        /// </summary>
        public void SearchBusinessUnit(IOrganizationService service)
        {
            RetrieveBusinessHierarchyBusinessUnitRequest request = new RetrieveBusinessHierarchyBusinessUnitRequest();
            request.EntityId = businessunitId;
            request.ColumnSet = new Microsoft.Xrm.Sdk.Query.ColumnSet("name", "parentbusinessunitid");
            RetrieveBusinessHierarchyBusinessUnitResponse response =
                (RetrieveBusinessHierarchyBusinessUnitResponse)service.Execute(request);
            if (response != null && response.EntityCollection != null)
            {
                List<BusinessUnit> list = new List<BusinessUnit>();
                EntityCollection ecResult = response.EntityCollection;
                int index = 1;
                #region 获取所有的部门
                foreach (Entity en in ecResult.Entities)
                {
                    BusinessUnit unitE = new BusinessUnit();
                    unitE.businessUnitId = en.Id;
                    unitE.name = en.Contains("name") && en["name"] != null ? en["name"].ToString() : string.Empty;
                    if (en.Contains("parentbusinessunitid") && en["parentbusinessunitid"] != null)
                    {
                        EntityReference parEr = en["parentbusinessunitid"] as EntityReference;
                        unitE.parentBusinessUnitId = parEr.Id;
                    }
                    unitE.order = index;

                    list.Add(unitE);
                    index++;
                }
                #endregion
                #region 重置业务部门的顺序
                foreach (BusinessUnit model in list)
                {
                    var result = list.Where(a => a.parentBusinessUnitId == a.businessUnitId);
                    if (result != null && result.Count() > 0)
                    {
                        var parModel = result.FirstOrDefault();
                        if (model.order + 1 != parModel.order) {
                            parModel.order = model.order + 1;
                        }
                    }
                }
                #endregion
            }
        }

        public class BusinessUnit
        {
            public Guid businessUnitId { get; set; }
            public string name { get; set; }
            public Guid parentBusinessUnitId { get; set; }
            public int order { get; set; }
        }

        /// <summary>
        /// 添加用户或者移除用户
        /// </summary>
        /// <param name="service">服务</param>
        /// <param name="userId">用户</param>
        public void AddAndRemoveUser(IOrganizationService service,Guid userId)
        {
            //添加用户
            AddConnection(service, "business_unit_system_users",
                new EntityReference() { LogicalName = "systemuser", Id = userId });
            //移除用户
            RemoveConnection(service, "business_unit_system_users",
                new EntityReference() { LogicalName = "systemuser", Id = userId });
        }

        /// <summary>
        /// 添加团队或者移除团队
        /// </summary>
        /// <param name="service">服务</param>
        /// <param name="teamId">团队</param>
        public void AddAndRemoveUser(IOrganizationService service, Guid teamId)
        {
            //添加团队
            AddConnection(service, "business_unit_teams",
                new EntityReference() { LogicalName = "team", Id = teamId });
            //移除团队
            RemoveConnection(service, "business_unit_teams",
                new EntityReference() { LogicalName = "team", Id = teamId });
        }

        /// <summary>
        /// 停用或者启用业务部门
        /// </summary>
        public void SetBusinessUnitState(IOrganizationService service)
        {
            //启用业务部门
            UpdateState(service, businessunitId, 0, -1);
            //停用业务部门
            UpdateState(service, businessunitId, -1, -1);
        }

        /// <summary>
        /// 删除业务部门
        /// </summary>
        public void DeleteUnit(IOrganizationService service)
        {
            service.Delete(entityName, businessunitId);
        }

        private void UpdateState(IOrganizationService service,Guid id, int state, int status)
        {
            SetStateRequest setState = new SetStateRequest()
            {
                EntityMoniker = new EntityReference()
                {
                    Id = id,
                    LogicalName = entityName
                },
                State = new OptionSetValue(state),
                Status = new OptionSetValue(status)
            };
            service.Execute(setState);
        }

        public void AddConnection(IOrganizationService service,string name,params EntityReference[] array)
        {
            Relationship ship = new Relationship(name);
            AssociateRequest request = new AssociateRequest();
            request.Relationship = ship;
            request.Target = new EntityReference() { LogicalName = entityName,Id = businessunitId };
            request.RelatedEntities = new EntityReferenceCollection();
            request.RelatedEntities.AddRange(array);
            service.Execute(request);
        }

        public void RemoveConnection(IOrganizationService service, string name, params EntityReference[] array)
        {
            Relationship ship = new Relationship(name);
            DisassociateRequest request = new DisassociateRequest();
            request.Relationship = ship;
            request.Target = new EntityReference() { LogicalName = entityName, Id = businessunitId };
            request.RelatedEntities = new EntityReferenceCollection();
            request.RelatedEntities.AddRange(array);
            service.Execute(request);
        }
    }

内容概要:本文详细探讨了基于MATLAB/SIMULINK的多载波无线通信系统仿真及性能分析,重点研究了以OFDM为代表的多载波技术。文章首先介绍了OFDM的基本原理和系统组成,随后通过仿真平台分析了不同调制方式的抗干扰性能、信道估计算法对系统性能的影响以及同步技术的实现与分析。文中提供了详细的MATLAB代码实现,涵盖OFDM系统的基本仿真、信道估计算法比较、同步算法实现和不同调制方式的性能比较。此外,还讨论了信道特征、OFDM关键技术、信道估计、同步技术和系统级仿真架构,并提出了未来的改进方向,如深度学习增强、混合波形设计和硬件加速方案。; 适合人群:具备无线通信基础知识,尤其是对OFDM技术有一定了解的研究人员和技术人员;从事无线通信系统设计与开发的工程师;高校通信工程专业的高年级本科生和研究生。; 使用场景及目标:①理解OFDM系统的工作原理及其在多径信道环境下的性能表现;②掌握MATLAB/SIMULINK在无线通信系统仿真中的应用;③评估不同调制方式、信道估计算法和同步算法的优劣;④为实际OFDM系统的设计和优化提供理论依据和技术支持。; 其他说明:本文不仅提供了详细的理论分析,还附带了大量的MATLAB代码示例,便于读者动手实践。建议读者在学习过程中结合代码进行调试和实验,以加深对OFDM技术的理解。此外,文中还涉及了一些最新的研究方向和技术趋势,如AI增强和毫米波通信,为读者提供了更广阔的视野。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值