IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> SAP RFC_CVI_EI_INBOUND_MAIN BP主数据创建示例(仅演示客户) -> 正文阅读

[游戏开发]SAP RFC_CVI_EI_INBOUND_MAIN BP主数据创建示例(仅演示客户)

1. 全局输入输出结构(数据通过Json String传输)

  • 定义全局结构
    TYPES: BEGIN OF TY_SD001,
             PARTNER          TYPE BUT000-PARTNER,     "客户编码
             BU_GROUP         TYPE BUT000-BU_GROUP,     "分组
             TITLE            TYPE BUT000-TITLE,     "称谓
             NAME_ORG1        TYPE BUT000-NAME_ORG1,     "名称
             BU_SORT1         TYPE BUT000-BU_SORT1,     "搜索项1
             BPEXT            TYPE BUT000-BPEXT,     "搜索项2
             STRAS            TYPE KNA1-STRAS,     "街道
             PSTLZ            TYPE KNA1-PSTLZ,     "邮政编码
             ORT01            TYPE KNA1-ORT01,     "城市
             REGIO            TYPE KNA1-REGIO,     "省/地区
             LAND1            TYPE KNA1-LAND1,     "国家
             SPRAS            TYPE char2,     "语言
             TELF1            TYPE KNA1-TELF1,     "电话
             TELFX            TYPE KNA1-TELFX,     "传真
             KATR1            TYPE KNA1-KATR1,     "属性1
             BRAN1            TYPE KNA1-BRAN1,     "行业代码1
             KUKLA            TYPE KNA1-KUKLA,     "客户分类
             BUKRS            TYPE KNB1-BUKRS,     "公司代码
             AKONT            TYPE KNB1-AKONT,     "统驭科目
             ZUAWA            TYPE KNB1-ZUAWA,     "排序码
             ZTERM            TYPE KNVV-ZTERM,     "付款条件
             VKORG            TYPE KNVV-VKORG,     "销售组织
             VTWEG            TYPE KNVV-VTWEG,     "分销渠道
             SPART            TYPE KNVV-SPART,     "产品组
             BZIRK            TYPE KNVV-BZIRK,     "销售区域
             KDGRP            TYPE KNVV-KDGRP,     "客户组
             KVGR1            TYPE KNVV-KVGR1,     "客户组1
             VKBUR            TYPE KNVV-VKBUR,     "销售部门
             VKGRP            TYPE KNVV-VKGRP,     "销售组
             WAERS            TYPE KNVV-WAERS,     "币种
             KONDA            TYPE KNVV-KONDA,     "价格组
             KALKS            TYPE KNVV-KALKS,     "定价过程
             KZAZU            TYPE KNVV-KZAZU,     "订单组合
             VWERK            TYPE KNVV-VWERK,     "交货工厂
             VSBED            TYPE KNVV-VSBED,     "装运条件
             INCO1            TYPE KNVV-INCO1,     "国际贸易条款
             INCO2_L          TYPE KNVV-INCO2_L,   "国际贸易位置
             KKBER            TYPE KNVV-KKBER,     "信用控制范围
             KTGRD            TYPE KNVV-KTGRD,     "客户账户分配组
             TAXKD            TYPE KNVI-TAXKD,     "税分类
             ALAND            TYPE KNVI-ALAND,     "国家/地区
             TATYP            TYPE KNVI-TATYP,     "税收类别
             TAXTYPE          TYPE DFKKBPTAXNUM-TAXTYPE,     "税号类别
             TAXNUMXL         TYPE DFKKBPTAXNUM-TAXNUMXL,     "税务登记证号
             BANKS            TYPE KNBK-BANKS,     "银行国家
             BANKL            TYPE KNBK-BANKL,     "银行代码
             BANKA            TYPE BNKA-BANKA,     "银行名称
             BANKN            TYPE KNBK-BANKN,     "银行账户
             BKREF            TYPE KNBK-BKREF,     "参考明细
             KOINH            TYPE KNBK-KOINH,     "账户持有人
             LIMIT_RULE       TYPE UKMBP_CMS-LIMIT_RULE,     "信用参数规则
             RISK_CLASS       TYPE UKMBP_CMS-RISK_CLASS,     "信用风险类
             CHECK_RULE       TYPE UKMBP_CMS-CHECK_RULE,     "信用检查规则
             CREDIT_SGMNT     TYPE UKMBP_CMS_SGM-CREDIT_SGMNT,     "信用段
             CREDIT_LIMIT     TYPE UKMBP_CMS_SGM-CREDIT_LIMIT,     "信用金额
             LIMIT_VALID_DATE TYPE UKMBP_CMS_SGM-LIMIT_VALID_DATE,     "有效至
             ATTRIBUTE1       TYPE  CHAR100,     "预留字段1
             ATTRIBUTE2       TYPE  CHAR100,     "预留字段2
             ATTRIBUTE3       TYPE  CHAR100,     "预留字段3
             ATTRIBUTE4       TYPE  CHAR100,     "预留字段4
             ATTRIBUTE5       TYPE  CHAR100,     "预留字段5
             ATTRIBUTE6       TYPE  CHAR100,     "预留字段6
             ATTRIBUTE7       TYPE  CHAR100,     "预留字段7
             ATTRIBUTE8       TYPE  CHAR100,     "预留字段8
             ATTRIBUTE9       TYPE  CHAR100,     "预留字段9
             ATTRIBUTE10      TYPE CHAR100,     "预留字段10
             ATTRIBUTE11      TYPE CHAR100,     "预留字段11
             ATTRIBUTE12      TYPE CHAR100,     "预留字段12
             ATTRIBUTE13      TYPE CHAR100,     "预留字段13
             ATTRIBUTE14      TYPE CHAR100,     "预留字段14
             ATTRIBUTE15      TYPE CHAR100,     "预留字段15
           END OF TY_SD001.
    
    
    TYPES: BEGIN OF TY_SD001_O,
             PARTNER TYPE BUT000-PARTNER,     "客户编码
             MSGTY   TYPE MSGTY,
             MSGTX   TYPE MSGTX,
             CRM_BP  TYPE CHAR20,
           END OF TY_SD001_O.
    

2. 传入参数

  • Json
{
	"PARTNER": "",
	"BU_GROUP": "Z020",
	"TITLE": "0003",
	"NAME_ORG1": "ABCDE",
	"BU_SORT1": "ABC",
	"BPEXT": "",
	"STRAS": "XXX街道XXX号",
	"PSTLZ": "322163",
	"ORT01": "北京市",
	"REGIO": "130",
	"LAND1": "CN",
	"SPRAS": "ZH",
	"TELF1": "0571-89664859",
	"TELFX": "0571-89664859",
	"KATR1": "01",
	"BRAN1": "0013",
	"KUKLA": "09",
	"BUKRS": "1000",
	"AKONT": "1111000002",
	"ZUAWA": "009",
	"ZTERM": "Z019",
	"VKORG": "1100",
	"VTWEG": "00",
	"SPART": "00",
	"BZIRK": "J00001",
	"KDGRP": "20",
	"KVGR1": "06",
	"VKBUR": "0010",
	"VKGRP": "023",
	"WAERS": "CNY",
	"KONDA": "01",
	"KALKS": "1",
	"KZAZU": "X",
	"VWERK": "1000",
	"VSBED": "01",
	"INCO1": "",
	"INCO2_L": "",
	"KKBER": "1000",
	"KTGRD": "Z2",
	"TAXKD": "1",
	"ALAND": "CN",
	"TATYP": "MWST",
	"TAXTYPE": "CN0",
	"TAXNUMXL": "91870169396378766W",
	"BANKS": "",
	"BANKL": "",
	"BANKA": "",
	"BANKN": "",
	"BKREF": "",
	"KOINH": "",
	"LIMIT_RULE": "STANDARD",
	"RISK_CLASS": "B",
	"CHECK_RULE": "ZXX01",
	"CREDIT_SGMNT": "ZXX01",
	"CREDIT_LIMIT": 0,
	"LIMIT_VALID_DATE": "0000-00-00",
	"ATTRIBUTE1": "",
	"ATTRIBUTE2": "",
	"ATTRIBUTE3": "",
	"ATTRIBUTE4": "",
	"ATTRIBUTE5": "",
	"ATTRIBUTE6": "",
	"ATTRIBUTE7": "",
	"ATTRIBUTE8": "",
	"ATTRIBUTE9": "",
	"ATTRIBUTE10": "",
	"ATTRIBUTE11": "",
	"ATTRIBUTE12": "",
	"ATTRIBUTE13": "",
	"ATTRIBUTE14": "",
	"ATTRIBUTE15": ""
}

3. 接口函数(示例为单条过账,批量请加Loop循环)

  • 接口主函数
FUNCTION zsd_if00010_crm.
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     VALUE(IV_INPUT) TYPE  STRING OPTIONAL
*"  EXPORTING
*"     VALUE(EV_OUTPUT) TYPE  STRING
*"  EXCEPTIONS
*"      NUM_RANGE_ERROR
*"----------------------------------------------------------------------
  DATA: ls_input TYPE ty_sd001.
  DATA: ls_output TYPE ty_sd001_o.
  DATA lv_seqnr   TYPE zeseqnr.

  DATA:ls_cvis_bp_general             TYPE cvis_bp_general,
       lt_cvis_bp_general             LIKE TABLE OF ls_cvis_bp_general,
       ls_cvis_bp_role                TYPE cvis_bp_role,
       lt_cvis_bp_role                LIKE TABLE OF ls_cvis_bp_role,
       ls_cvis_bp_tax_number          TYPE cvis_bp_tax_number,
       lt_cvis_bp_tax_number          LIKE TABLE OF ls_cvis_bp_tax_number,
       ls_cvis_bp_address             TYPE cvis_bp_address,
       lt_cvis_bp_address             LIKE TABLE OF ls_cvis_bp_address,
       ls_cvis_bp_address_teleno      TYPE cvis_bp_address_teleno, "电话号码
       lt_cvis_bp_address_teleno      LIKE TABLE OF ls_cvis_bp_address_teleno,
       ls_cvis_bp_address_faxno       TYPE cvis_bp_address_faxno,
       lt_cvis_bp_address_faxno       LIKE TABLE OF ls_cvis_bp_address_faxno, "传真号码
       ls_cvis_bp_address_email       TYPE cvis_bp_address_email,
       lt_cvis_bp_address_email       LIKE TABLE OF ls_cvis_bp_address_email, "邮箱号码
       ls_cvis_bp_finserv             TYPE cvis_bp_finserv,
       lt_cvis_bp_finserv             LIKE TABLE OF cvis_bp_finserv,          "分组字符
       ls_cvis_customer_company       TYPE cvis_customer_company,
       lt_cvis_customer_company       LIKE TABLE OF ls_cvis_customer_company, "公司代码
       ls_cvis_customer_sales         TYPE cvis_customer_sales,
       lt_cvis_customer_sales         LIKE TABLE OF ls_cvis_customer_sales,   "销售视图相关
       ls_cvis_customer_sales_func    TYPE cvis_customer_sales_func,
       lt_cvis_customer_sales_func    LIKE TABLE OF ls_cvis_customer_sales_func, "伙伴功能
       ls_cvis_customer_tax_indicator TYPE cvis_customer_tax_indicator,
       lt_cvis_customer_tax_indicator LIKE TABLE OF ls_cvis_customer_tax_indicator, "销售视图税
       ls_cvis_customer_general       TYPE cvis_customer_general,
       lt_cvis_customer_general       LIKE TABLE OF ls_cvis_customer_general,
*       ls_cvis_supplier_general LIKE cvis_supplier_general,
*       lt_cvis_supplier_general LIKE TABLE OF ls_cvis_supplier_general,
*       ls_cvis_bp_ident_numbers LIKE cvis_bp_ident_numbers,
*       lt_cvis_bp_ident_numbers LIKE TABLE OF ls_cvis_bp_ident_numbers,
       ls_cvis_bp_bank_details        LIKE cvis_bp_bank_details,
       lt_cvis_bp_bank_details        LIKE TABLE OF ls_cvis_bp_bank_details,
       lt_cvis_bp_return              LIKE  TABLE OF cvis_bp_return.

  DATA: lt_return TYPE ukm_t_monitor_return.

  DATA: l_run_id TYPE cvi_run_id,
        lv_guid  TYPE but000-partner_guid.

  /ui2/cl_json=>deserialize( EXPORTING json = iv_input CHANGING data = ls_input ).
  CLEAR ls_output.

  " check data
  IF ls_input-bu_group IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '分组(BU_GROUP):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-title IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '称谓(TITLE):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-name_org1 IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '名称(NAME_ORG1):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-bu_sort1 IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '搜索项1(BU_SORT1):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-stras IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '街道(STRAS):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-land1 IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '国家(LAND1):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-spras IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '语言(SPRAS):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-bukrs IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '公司代码(BUKRS):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-akont IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '统驭科目(AKONT):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-zuawa IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '排序码(ZUAWA):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-zterm IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '付款条件(ZTERM):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-vkorg IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '销售组织(VKORG):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-vtweg IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '分销渠道(VTWEG):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-spart IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '产品组(SPART):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-bzirk IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '销售区域(BZIRK):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-kdgrp IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '客户组(KDGRP):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-vkbur IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '销售部门(VKBUR):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-vkgrp IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '销售组(VKGRP):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-waers IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '币种(WAERS):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-kalks IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '定价过程(KALKS):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-taxkd IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '税分类(TAXKD):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-aland IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '国家/地区(ALAND):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSEIF ls_input-tatyp IS INITIAL.
    ls_output-msgty = 'E'.
    ls_output-msgtx = '税收类别(TATYP):值必输!'.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ENDIF.

  "Process data
  "统驭科目
  IF ls_input-partner IS NOT INITIAL.
    ls_input-partner = |{ ls_input-partner ALPHA = IN }|.

    "Determine UPDATE OR CREATE?
    SELECT SINGLE partner_guid INTO lv_guid                 "业务伙伴是否存在
        FROM but000 WHERE partner = ls_input-partner.
    IF lv_guid IS NOT INITIAL.
      ls_cvis_bp_general-object_task = 'U'.                 "I:创建BP U:修改BP
    ELSE.                                                  "输入了值,实际数据库没有
      TRY.
          CALL METHOD cl_system_uuid=>if_system_uuid_static~create_uuid_c32
            RECEIVING
              uuid = lv_guid. "唯一标识
        CATCH cx_uuid_error .
      ENDTRY.
      ls_cvis_bp_general-object_task = 'I'.                 "I:创建BP U:修改BP
      CLEAR ls_input-partner.
    ENDIF.
  ELSE.
    TRY.
        CALL METHOD cl_system_uuid=>if_system_uuid_static~create_uuid_c32
          RECEIVING
            uuid = lv_guid. "唯一标识
      CATCH cx_uuid_error .
    ENDTRY.
    ls_cvis_bp_general-object_task = 'I'.                 "I:创建BP U:修改BP
  ENDIF.

  ls_input-akont = |{ ls_input-akont ALPHA = IN }|.
  l_run_id = '1000000'.

* bp_general 一般数据赋值
  ls_cvis_bp_general-run_id = l_run_id.    "用于区分不同实例的 CVI 运行标识
  ls_cvis_bp_general-category = '2'.        "业务伙伴类别
  ls_cvis_bp_general-bpartnerguid = lv_guid.     "GUID

  ls_cvis_bp_general-grouping = ls_input-bu_group.      "业务合作伙伴组
  ls_cvis_bp_general-title_key = ls_input-title.        "称谓
  ls_cvis_bp_general-name1 = ls_input-name_org1.        "名称
  ls_cvis_bp_general-searchterm1 = ls_input-bu_sort1.   "搜索项1
  ls_cvis_bp_general-searchterm2 = ls_input-bpext.      "搜索项2

  APPEND ls_cvis_bp_general TO lt_cvis_bp_general.
  CLEAR ls_cvis_bp_general.

*bp_address 地址数据
  ls_cvis_bp_address-run_id = l_run_id.
  ls_cvis_bp_address-guid = lv_guid.                  "GUID
  ls_cvis_bp_address-comm_type = 'INT'.               "通讯方法 (关键字)(业务地址服务)
  ls_cvis_bp_address-street = ls_input-stras.         "街道street-str_suppl1-str_supp2-str_suppl3
  ls_cvis_bp_address-postl_cod1 = ls_input-pstlz.     "邮编
  ls_cvis_bp_address-city = ls_input-ort01.           "城市
  ls_cvis_bp_address-region = ls_input-regio.         "省/地区
  ls_cvis_bp_address-country = ls_input-land1.        "国家

  CALL FUNCTION 'CONVERSION_EXIT_ISOLA_INPUT'
    EXPORTING
      input            = ls_input-spras
    IMPORTING
      output           = ls_cvis_bp_address-langu     "语言
    EXCEPTIONS
      unknown_language = 1
      OTHERS           = 2.

  APPEND ls_cvis_bp_address TO lt_cvis_bp_address.
  CLEAR ls_cvis_bp_address.

*bp_Contact
  ls_cvis_bp_address_teleno-run_id    = l_run_id.
  ls_cvis_bp_address_teleno-country   = ls_input-land1.
  ls_cvis_bp_address_teleno-telephone = ls_input-telf1.       "电话
  IF strlen( ls_input-telf1 ) = 11.
    ls_cvis_bp_address_teleno-r_3_user = '2'."1	电话是缺省陆上电缆电话 2	电话是移动电话不是缺省陆上电缆电话 3	电话是缺省移动电话
  ENDIF.
  APPEND ls_cvis_bp_address_teleno TO lt_cvis_bp_address_teleno .
  CLEAR ls_cvis_bp_address_teleno.

  ls_cvis_bp_address_faxno-run_id    = l_run_id.
  ls_cvis_bp_address_faxno-country   = ls_input-land1.
  ls_cvis_bp_address_faxno-fax       = ls_input-telfx.  "传真
  APPEND ls_cvis_bp_address_faxno TO lt_cvis_bp_address_faxno.
  CLEAR ls_cvis_bp_address_faxno.

*bp_role
  ls_cvis_bp_role-run_id =  l_run_id.
  ls_cvis_bp_role-data_key = 'JPCU01'.        "业务伙伴角色
  APPEND ls_cvis_bp_role TO lt_cvis_bp_role.
  CLEAR ls_cvis_bp_role.

  ls_cvis_bp_role-run_id =  l_run_id.
  ls_cvis_bp_role-data_key = 'JPCU02'.        "业务伙伴角色
  APPEND ls_cvis_bp_role TO lt_cvis_bp_role.
  CLEAR ls_cvis_bp_role.

  ls_cvis_bp_role-run_id =  l_run_id.
  ls_cvis_bp_role-data_key = 'UKM000'.        "业务伙伴角色
  APPEND ls_cvis_bp_role TO lt_cvis_bp_role.
  CLEAR ls_cvis_bp_role.

*bp_cus_general
  ls_cvis_customer_general-object_task = ls_cvis_bp_general-object_task.
  ls_cvis_customer_general-run_id =  l_run_id.
  ls_cvis_customer_general-katr1 = ls_input-katr1.   "属性1
  ls_cvis_customer_general-bran1 = ls_input-bran1.   "行业代码1
  ls_cvis_customer_general-kukla = ls_input-kukla.    "客户分类
  APPEND ls_cvis_customer_general TO lt_cvis_customer_general.
  CLEAR ls_cvis_customer_general.

  ls_cvis_customer_company-run_id = l_run_id.
  ls_cvis_customer_company-bukrs  = ls_input-bukrs. "公司代码
  ls_cvis_customer_company-akont  = ls_input-akont . "总帐中的统驭科目
  ls_cvis_customer_company-zuawa = ls_input-zuawa.   "排序码
  ls_cvis_customer_company-zterm  = ls_input-zterm.  "付款条件
  APPEND ls_cvis_customer_company TO lt_cvis_customer_company . "公司代码
  CLEAR ls_cvis_customer_company.

*bp_sales
  ls_cvis_customer_sales-run_id = l_run_id.
  ls_cvis_customer_sales-vkorg = ls_input-bukrs.    "销售组织.
  ls_cvis_customer_sales-vtweg = ls_input-vtweg.    "分销渠道
  ls_cvis_customer_sales-spart = ls_input-spart.    "产品组
  ls_cvis_customer_sales-bzirk = ls_input-bzirk.    "销售地区
  ls_cvis_customer_sales-kdgrp = ls_input-kdgrp.    "客户组
  ls_cvis_customer_sales-kvgr1 = ls_input-kvgr1.    "客户组1
  ls_cvis_customer_sales-vkbur = ls_input-vkbur.    "销售部门
  ls_cvis_customer_sales-vkgrp = ls_input-vkgrp.    "销售组
  ls_cvis_customer_sales-waers = ls_input-waers.    "币种
  ls_cvis_customer_sales-konda = ls_input-konda.    "价格组
  ls_cvis_customer_sales-kalks = ls_input-kalks.    "定价过程
  ls_cvis_customer_sales-kzazu = ls_input-kzazu.    "订单组合
  ls_cvis_customer_sales-vwerk = ls_input-vwerk.    "交货工厂
  ls_cvis_customer_sales-vsbed = ls_input-vsbed.    "装运条件
  ls_cvis_customer_sales-inco1 = ls_input-inco1.    "国际贸易条款
  ls_cvis_customer_sales-zterm = ls_input-zterm.  "付款条件
  ls_cvis_customer_sales-inco2_l = ls_input-inco2_l.    "国际贸易位置
  ls_cvis_customer_sales-kkber = ls_input-kkber.    "信用控制范围
  ls_cvis_customer_sales-ktgrd = ls_input-ktgrd.    "客户账户分配组
  APPEND ls_cvis_customer_sales TO lt_cvis_customer_sales.
  CLEAR ls_cvis_customer_sales.

  ls_cvis_customer_sales_func-run_id = l_run_id.
  ls_cvis_customer_sales_func-vkorg = ls_input-bukrs."销售组织.
  ls_cvis_customer_sales_func-vtweg = ls_input-vtweg. "分销渠道
  ls_cvis_customer_sales_func-spart = ls_input-spart.  "产品组

  ls_cvis_customer_sales_func-parvw   = 'AG'."伙伴功能    SP
*  LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
  APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.

  ls_cvis_customer_sales_func-parvw   = 'RE'."伙伴功能    BP
*  LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
  APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.

  ls_cvis_customer_sales_func-parvw   = 'RG'."伙伴功能    PY
*  LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
  APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.

  ls_cvis_customer_sales_func-parvw   = 'WE'."伙伴功能    SH
*  LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
  APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.
  CLEAR ls_cvis_customer_sales_func.

*bp_tax
  ls_cvis_customer_tax_indicator-run_id = l_run_id.
  ls_cvis_customer_tax_indicator-taxkd  = ls_input-taxkd.   "税分类
  ls_cvis_customer_tax_indicator-aland = ls_input-aland.    "税-国家/地区
  ls_cvis_customer_tax_indicator-tatyp = ls_input-tatyp.    "税类别
  APPEND  ls_cvis_customer_tax_indicator TO lt_cvis_customer_tax_indicator. "销售视图税
  CLEAR  ls_cvis_customer_tax_indicator.

  IF ls_input-taxnumxl IS NOT INITIAL.
    ls_cvis_bp_tax_number-run_id = l_run_id.
    ls_cvis_bp_tax_number-taxtype = ls_input-taxtype.   "税号类别
    ls_cvis_bp_tax_number-taxnumber = ls_input-taxnumxl.  "税务登记证号
    APPEND ls_cvis_bp_tax_number TO lt_cvis_bp_tax_number.
    CLEAR ls_cvis_bp_tax_number.
  ENDIF.

*bp_bank_detail
  IF ls_input-bankl IS NOT INITIAL.
    ls_cvis_bp_bank_details-run_id =  l_run_id.
    ls_cvis_bp_bank_details-bank_ctry = ls_input-banks.  "银行国家
    ls_cvis_bp_bank_details-bank_key = ls_input-bankl.  "银行代码
    ls_cvis_bp_bank_details-bank_acct = ls_input-bankn.  "银行账号
    ls_cvis_bp_bank_details-bank_ref = ls_input-bkref.  "银行账号的参考明细
    ls_cvis_bp_bank_details-accountholder = ls_input-koinh.  "账户持有人
    APPEND ls_cvis_bp_bank_details TO lt_cvis_bp_bank_details.
    CLEAR ls_cvis_bp_bank_details.
  ENDIF.

  CALL FUNCTION 'RFC_CVI_EI_INBOUND_MAIN'
    EXPORTING
      iv_docommit             = 'X'
      iv_create_applog        = 'X'               "API Logging 可通过SLG1查看
    TABLES
      it_bp_general           = lt_cvis_bp_general
      it_bp_role              = lt_cvis_bp_role
      it_bp_tax_number        = lt_cvis_bp_tax_number
      it_bp_address_teleno    = lt_cvis_bp_address_teleno "电话号码
      it_bp_address_faxno     = lt_cvis_bp_address_faxno "传真号码
      it_bp_address_email     = lt_cvis_bp_address_email "邮箱号码
      it_bp_finserv           = lt_cvis_bp_finserv "分组字符
*     it_bp_ident_numbers     = lt_cvis_bp_ident_numbers
      it_cust_general         = lt_cvis_customer_general
      it_cust_company         = lt_cvis_customer_company "公司代码
      it_cust_sales           = lt_cvis_customer_sales "销售视图相关
      it_cust_sales_functions = lt_cvis_customer_sales_func  "伙伴功能
      it_cust_tax_indicator   = lt_cvis_customer_tax_indicator "销售视图税
*     it_sup_general          = lt_cvis_supplier_general
      it_bp_bank_details      = lt_cvis_bp_bank_details
      it_bp_address           = lt_cvis_bp_address
      ct_return               = lt_cvis_bp_return.

  IF line_exists( lt_cvis_bp_return[ type = 'E' ] ) OR
      line_exists( lt_cvis_bp_return[ type = 'A' ] ).

    SELECT SINGLE * FROM
      @lt_cvis_bp_return AS a
      WHERE type IN ( 'A','E' )
      INTO @DATA(wa_cvis_bp_return).
    ls_output-msgty = wa_cvis_bp_return-type.
    ls_output-msgtx = |创建BP失败!消息号:{ wa_cvis_bp_return-id }{ wa_cvis_bp_return-number } 消息文本:{ wa_cvis_bp_return-message }|.
    ev_output = /ui2/cl_json=>serialize( ls_output ).
    EXIT.
  ELSE.
    ls_output-crm_bp = ls_input-bpext.   "CRM BP = 搜索项2
    SELECT SINGLE object_key                "BP 编号
      FROM @lt_cvis_bp_return AS a
      WHERE object_key <> ''
      AND type = 'S'
      INTO @ls_output-partner.

    ls_output-msgty = 'S'.
    ls_output-msgtx = 'BP创建成功'.
    ls_input-partner = ls_output-partner.

    PERFORM frm_bp_sgm USING ls_input CHANGING lt_return.      "Region 信用段数据维护

    IF line_exists( lt_return[ msgty = 'E' ] ) OR
        line_exists( lt_return[ msgty = 'A' ] ).

      SELECT SINGLE * FROM
        @lt_return AS a
        WHERE msgty IN ( 'A','E' )
        INTO @DATA(wa_return).

      ls_output-msgty = wa_return-msgty.
      ls_output-msgtx = ls_output-msgtx && '/' && |创建BP失败!消息号:{ wa_return-msgid }{ wa_return-msgno } 消息文本:{ wa_return-message }|.
      ev_output = /ui2/cl_json=>serialize( ls_output ).
      EXIT.
    ELSE.
      ls_output-msgtx = ls_output-msgtx && '/' && 'BP信用创建成功!'.
      ev_output = /ui2/cl_json=>serialize( ls_output ).
    ENDIF.
  ENDIF.

  REFRESH:lt_cvis_bp_general,
          lt_cvis_bp_role,
          lt_cvis_bp_tax_number,
          lt_cvis_bp_bank_details,
          lt_cvis_bp_address_teleno, "电话号码
          lt_cvis_bp_address_faxno, "传真号码
          lt_cvis_bp_address_email, "邮箱号码
          lt_cvis_bp_finserv, "分组字符
*            lt_cvis_bp_ident_numbers,
          lt_cvis_customer_general,
          lt_cvis_customer_company, "公司代码
          lt_cvis_customer_sales, "销售视图相关
          lt_cvis_customer_tax_indicator, "销售视图税
          lt_cvis_customer_sales_func,"伙伴功能
*            lt_cvis_supplier_general,
*            lt_cvis_bp_bank_details,
          lt_cvis_bp_address,
          lt_cvis_bp_return.

  CLEAR: lt_return,lv_guid.

ENDFUNCTION.
  • 信用&信用段维护函数:frm_bp_sgm
FORM frm_bp_sgm  USING    p_ls_input TYPE ty_sd001
                 CHANGING p_return TYPE ukm_t_monitor_return.


  DATA : io_facade        TYPE REF TO cl_ukm_facade,
         io_calculator    TYPE REF TO if_ukm_calculator,
         io_partner       TYPE REF TO cl_ukm_business_partner,
         io_bupa_factory  TYPE REF TO cl_ukm_bupa_factory,
         io_account       TYPE REF TO cl_ukm_account,
         lw_bp_credit_sgm TYPE ukm_s_bp_cms_sgm,
         lw_ukm_s_bp_cms  TYPE ukm_s_bp_cms.

  IF p_ls_input-risk_class IS NOT INITIAL.
*  创建'MAINTAIN'对象
    io_facade = cl_ukm_facade=>create( i_activity = cl_ukm_cnst_eventing=>bp_maintenance ).
    io_calculator = io_facade->get_calculator( ).
    io_bupa_factory = io_facade->get_bupa_factory( ).

*read businee partner
    io_partner = io_bupa_factory->get_business_partner( p_ls_input-partner ).

    CALL METHOD io_bupa_factory->get_credit_account
      EXPORTING
        i_partner         = p_ls_input-partner          "客户代码
        i_credit_sgmnt    = p_ls_input-credit_sgmnt     "信用段
      RECEIVING
        ro_credit_account = io_account.

    io_account->get_bp_cms_sgm( IMPORTING es_bp_cms_sgm = lw_bp_credit_sgm ).

*信用
    lw_ukm_s_bp_cms-risk_class      = p_ls_input-risk_class. "风险类
    lw_ukm_s_bp_cms-check_rule      = p_ls_input-check_rule. "检查规则
    lw_ukm_s_bp_cms-limit_rule      = p_ls_input-limit_rule."信用参数文件记分规则

    io_partner->set_bp_cms( lw_ukm_s_bp_cms ).

*信用段

    lw_bp_credit_sgm-credit_limit = p_ls_input-credit_limit."信用金额
    lw_bp_credit_sgm-xcritical = 'X'.
    lw_bp_credit_sgm-limit_chg_date = sy-datum.
    lw_bp_credit_sgm-limit_valid_date = p_ls_input-limit_valid_date.  "有效至

    io_account->set_bp_cms_sgm( EXPORTING is_bp_cms_sgm = lw_bp_credit_sgm ).
    io_bupa_factory->save_all( EXPORTING i_upd_task = abap_false
        RECEIVING et_return = p_return   ).

    IF line_exists( p_return[ msgty = 'E' ] ) OR
        line_exists( p_return[ msgty = 'A' ] ).
      ROLLBACK WORK.
    ELSE.
      COMMIT WORK AND WAIT.
    ENDIF.
  ENDIF.
ENDFORM.

4. 其他

  • SLG1可查看RFC_CVI_EI_INBOUND_MAIN创建的错误日志
    1
  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-04-23 11:07:26  更:2022-04-23 11:07:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 22:03:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码