using System;

    using Microsoft.Xrm.Sdk;

    using Microsoft.Xrm.Sdk.Query;

    using Microsoft.Crm.Sdk.Messages;

/// <summary>

    /// 销售订单

    /// </summary>

    public class SoleOrderHelper

    {

        public static readonly string entityName = "salesorder";

        public Guid soleorderId = Guid.Empty;

        public IOrganizationService service;

/// <summary>

        /// 创建销售订单

        /// </summary>

        public void Create(Guid accountId)

        {

            Entity en = new Entity() { LogicalName = entityName,Id = accountId };

            en["name"] = "销售订单測试";

            en["accountid"] = new EntityReference() { LogicalName = "account" ,Id = accountId };

            soleorderId = service.Create(en);

        }

/// <summary>

        /// 将销售订单分派给其它用户或团队

        /// </summary>

        /// <param name="assignee">用户或团队引用</param>

        public void Assign(EntityReference assignee)

        {

            AssignRequest request = new AssignRequest();

            request.Target = new EntityReference() { LogicalName = entityName,Id = soleorderId };

            request.Assignee = assignee;

            AssignResponse response = (AssignResponse)service.Execute(request);

        }

/// <summary>

        /// 取消销售订单

        /// </summary>

        /// <param name="status">取消的状态</param>

        public void CancelSalesOrder(int status)

        {

            CancelSalesOrderRequest request = new CancelSalesOrderRequest();

            request.OrderClose = new Entity() { LogicalName = entityName,Id = soleorderId };

            request.Status = new OptionSetValue(status);

            CancelSalesOrderResponse response = (CancelSalesOrderResponse)service.Execute(request);

        }

/// <summary>

        /// 将销售订单转换为发票

        /// </summary>

        public void ConvertSalesOrderToInvoice()

        {

            ConvertSalesOrderToInvoiceRequest request = new ConvertSalesOrderToInvoiceRequest();

            request.SalesOrderId = soleorderId;

            request.ColumnSet = new ColumnSet("name","accountid");

            ConvertSalesOrderToInvoiceResponse response = (ConvertSalesOrderToInvoiceResponse)service.Execute(request);

            Entity invoiceEn = response.Entity;

        }

/// <summary>

        /// 完毕销售订单

        /// </summary>

        /// <param name="status">完毕的状态</param>

        public void FulfillSalesOrder(int status)

        {

            FulfillSalesOrderRequest request = new FulfillSalesOrderRequest();

            request.OrderClose = new Entity() { LogicalName = entityName,Id = soleorderId };

            request.Status = new OptionSetValue(status);

            FulfillSalesOrderResponse response = (FulfillSalesOrderResponse)service.Execute(request);

        }

/// <summary>

        /// 从指定商机中检索销售订单的产品组

        /// </summary>

        /// <param name="opportunityId">商机id</param>

        public void GetSalesOrderProductsFromOpportunity(Guid opportunityId)

        {

            GetSalesOrderProductsFromOpportunityRequest request = new GetSalesOrderProductsFromOpportunityRequest();

            request.OpportunityId = opportunityId;

            request.SalesOrderId = soleorderId;

            GetSalesOrderProductsFromOpportunityResponse response =

                (GetSalesOrderProductsFromOpportunityResponse)service.Execute(request);

        }

/// <summary>

        /// 锁定销售订单定价

        /// </summary>

        public void LockSalesOrderPricing()

        {

            LockSalesOrderPricingRequest request = new LockSalesOrderPricingRequest();

            request.SalesOrderId = soleorderId;

            LockSalesOrderPricingResponse response = (LockSalesOrderPricingResponse)service.Execute(request); 


        }

/// <summary>

        /// 解锁指定的销售订单(订单)中产品的单位价格

        /// </summary>

        public void UnlockSalesOrderPricing()

        {

            UnlockSalesOrderPricingRequest request = new UnlockSalesOrderPricingRequest();

            request.SalesOrderId = soleorderId;

            UnlockSalesOrderPricingResponse response = (UnlockSalesOrderPricingResponse)service.Execute(request);


        }

/// <summary>

        /// 取消指定安全主体(用户或团队)对销售订单的全部訪问权限

        /// </summary>

        /// <param name="revokee">用户或团队引用</param>

        public void RevokeAccess(EntityReference revokee)

        {

            RevokeAccessRequest request = new RevokeAccessRequest();

            request.Target = new EntityReference() { LogicalName = entityName,Id = soleorderId };

            request.Revokee = revokee;

            RevokeAccessResponse response = (RevokeAccessResponse)service.Execute(request);

        }

/// <summary>

        /// 删除销售订单

        /// </summary>

        public void Delete()

        {

            service.Delete(entityName, soleorderId);

        }

    }

crm操作销售订单实体的更多相关文章

  1. crm操作知识库文章实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages;     using Microsoft ...

  2. crm操作报价单实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages;     using Microsoft ...

  3. Netsharp快速入门(之11) 销售管理(开发销售订单工作区)

    作者:秋时 杨昶   时间:2014-02-15  转载须说明出处 4.3     销售订单开发 4.3.1  部件工作区设置 1.创建部件工作区,建工作区向导中要注意勾选组合并系部分.具体要建立的部 ...

  4. Netsharp快速入门(之13) 销售管理(单据流转 销售订单生成发货单)

    作者:秋时 杨昶   转载须说明出处 4.5     单据流转 4.5.1  单据流转的目的 单据流转主要为了实现业务关系的流转,并记录相互之间的关系.例如从销售订单生成销货单,两张单据之间有对应的关 ...

  5. Odoo开源ERP:功能模块操作-销售功能篇

    客户基础资料 1. 所有的客户基础资料,智云ERP开账启用时,期初的客户数据如果大于200条,可以批量导入: 2. 点“销售/订单/客户”菜单可以查看.编辑修改.搜索所有的客户基础资料: 3. 多层级 ...

  6. [置顶]生鲜配送管理系统_升鲜宝V2.0 销售订单汇总_采购任务分配功能_操作说明

    做好生鲜供应链系统,要注意三个方面,1.分拣 2 采购  3 库存,市面上做的比较成熟的功能,还是分拣这一块(按客户分拣.按订单分拣.按商品分类分拣.按商品分拣.按线路分拣.客户自由组合分拣)[下篇文 ...

  7. 转载]SAP囚徒 - 通过销售订单领用到成本中心,FI替代

    转载]SAP囚徒 - 通过销售订单领用到成本中心,FI替代   原文地址:SAP囚徒 - 通过销售订单领用到成本中心,FI替代实现不同成本中心记账科目不同作者:SAP囚徒 物品领用通常是库存管理的范畴 ...

  8. AR_销售订单收款基本操作(流程)

    2014-06-04 Created By BaoXinjian

  9. 为什么S/4HANA的销售订单创建会触发生产订单的创建

    调用S/4HANA销售订单创建函数SD_SALES_DOCU_MAINTAIN创建一个销售订单时,会触发生产订单的创建. 销售订单的每个行项目对应一个独立的生产订单,SD_SALES_DOCU_MAI ...

随机推荐

  1. [中山市选]杀人游戏 (Tarjan缩点)

    题目链接 Solution 可以考虑到如果知道环内一点的身份,如果凶手在其中就查出来了,同时不会有危险. 那么对警察造成威胁的就是那些身份不明且不能从其他点转移过来的点. 那么大部答案就是缩完点之后入 ...

  2. 单线程实现并发——协程,gevent模块

    一 并发的本质 1 切换 2 保存状态 二 协程的概念 协程,又称微线程,纤程.英文名Coroutine.单线程下实现并发,用户从应用程序级别控制单线程下任务的切换,注意一定是遇到I/O才切. 协程的 ...

  3. 关于vue属性绑定的问题

    <el-submenu index="></el-submenu> 类似于这样的形式,这里的index是以string的数据格式存在的. <el-submenu ...

  4. svn的简单知识

    svn的简单知识 一.简介: SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS.CVS,它采用了分支管理系统, 它的设计目标就是取代CVS.互联网上很多版本控制服务已从 ...

  5. sql server 2008导入和导出sql文件

    导出表数据和表结构sql文件 在日常的开发过程中,经常需要导出某个数据库中,某些表数据:或者,需要对某个表的结构,数据进行修改的时候,就需要在数据库中导出表的sql结构,包括该表的建表语句和数据存储语 ...

  6. BZOJ2527Meteors

    BZOJ2527 整体二分模板题 整体二分: 主要用于解决第K大问题 #include<cstdio> #include<cctype> #include<vector& ...

  7. ARM 浮点运算

    转载: http://www.embedu.org/Column/Column821.htm http://blog.sina.com.cn/s/blog_602f87700100r5xe.html ...

  8. SpringMVC中 Controller的 @ResponseBody注解分析

    需求分析:需要 利用    out 对象返回给财付通是否接收成功 .那么将需要如下代码: /** * 返回处理结果给财付通服务器. * @param msg: Success or fail. * @ ...

  9. filter和spring 的interceptor都是单例的,都不是线程安全的

    Filter 是在 Servlet 容器启动时就初始化的,因此可以认为是以单例对象存在的,如果一个请求线程对其中的成员变量修改的话,会影响到其他的请求线程,因此认为是多线程不安全的.

  10. sqlalchemy如何实现时间列自动更新?

    目标:数据表的时间列在其他列内容更新的时候,自动更新时间列到更新的时间 方法:数据库表模型如下:server_default表示初始时间,onupdate表示更新的时间 class MonitorDa ...