创建销售订单BAPI BAPI_SALESORDER_CREATEFROMDAT2

2023-11-02 22:12

本文主要是介绍创建销售订单BAPI BAPI_SALESORDER_CREATEFROMDAT2,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

TYPES: BEGIN OF TY_DATA,
         ZLINE  TYPE NUMC4,
         AUART  TYPE VBAK-AUART,       "订单类型
         VKORG  TYPE VBAK-VKORG,       "销售组织
         VTWEG  TYPE VBAK-VTWEG,       "分销渠道
         SPART  TYPE VBAK-SPART,       "产品组
         VKBUR  TYPE VBAK-VKBUR,       "销售办事处
         VKGRP  TYPE VBAK-VKGRP,       "销售组
         KUNNR  TYPE VBAK-KUNNR,       "售达方
         KUNWE  TYPE VBAK-KUNNR,       "送达方
         BSTNK  TYPE VBAK-BSTNK,       "客户参考
         ZYWY   TYPE VBAK-ZYWY,        "业务员

         PRSDT  TYPE VBKD-PRSDT,       "定价日期
         ZTERM  TYPE VBKD-ZTERM,       "付款条件

         CMTD   TYPE VBAP-CMTD_DELIV_DATE, "交货日期
         MATNR  TYPE VBAP-MATNR,       "物料编码
         KWMENG TYPE VBAP-KWMENG,      "数量
         PSTYV  TYPE VBAP-PSTYV,       "项目类别
         NETWR  TYPE VBAP-NETWR,       "价格
         KPEIN  TYPE VBAP-KPEIN,       "价格单位
         WERKS  TYPE VBAP-WERKS,       "工厂
         WAERK  TYPE VBAP-WAERK,       "货币
         KSCHA  TYPE KSCHA,            "条件类型

         MEINS  TYPE MARA-MEINS,       "计量单位
         STATUS TYPE ICON_D,           "返回状态
         MSG    TYPE MSGTXT_LONG,      "报错信息
         VBELN  TYPE VBELN,            "生成的销售订单
         LGORT  TYPE LIPS-LGORT,       "库存地点
       END OF TY_DATA,
       BEGIN OF TY_MSG,
         VBELN  TYPE VBELN,
         ZLINE  TYPE NUMC4,
         LGORT  TYPE LIPS-LGORT,
         STATUS TYPE ICON_D,
         MSG    TYPE MSGTXT_LONG,
         CMTD   TYPE VBAP-CMTD_DELIV_DATE, "交货日期
       END OF TY_MSG.
DATA: GT_DATA  TYPE TABLE OF TY_DATA.
DATA: GS_DATA TYPE TY_DATA.
DATA: LT_RETURN   TYPE TABLE OF BAPIRET2 WITH HEADER LINE,
      LT_PARTNERS TYPE TABLE OF BAPIPARNR WITH HEADER LINE,
      LT_ITEMS    TYPE TABLE OF BAPISDITM WITH HEADER LINE,
      LT_ITEMSX   TYPE TABLE OF BAPISDITMX WITH HEADER LINE,
      LT_SCHDL    TYPE TABLE OF BAPISCHDL WITH HEADER LINE,
      LT_SCHDLX   TYPE TABLE OF BAPISCHDLX WITH HEADER LINE,
      LT_COND     TYPE TABLE OF BAPICOND WITH HEADER LINE,
      LT_CONDX    TYPE TABLE OF BAPICONDX WITH HEADER LINE.

DATA: LS_HEADER  TYPE BAPISDHD1,   "销售订单抬头
      LS_HEADERX TYPE BAPISDHD1X.

DATA: BAPE_VBAK  TYPE BAPE_VBAK,
      BAPE_VBAKX TYPE BAPE_VBAKX.

DATA: LT_EXTENSIONIN TYPE TABLE OF BAPIPAREX,
      LS_EXTENSIONIN TYPE BAPIPAREX.

FIELD-SYMBOLS: <FS_DATA>  TYPE TY_DATA.
DATA LT_VBAP TYPE TABLE OF VBAP WITH HEADER LINE.
DATA: L_VBELN TYPE VBELN_VL,
      L_VBNUM TYPE VBNUM,
      L_RFLAG TYPE C,
      L_STR   TYPE STRING.
DATA BAPIRET2 TYPE TABLE OF BAPIRET2 WITH HEADER LINE.
DATA LV_VBELN TYPE BAPIVBELN-VBELN.
DATA LV_POSNR TYPE POSNR.
DATA LV_FLAG TYPE ABAP_BOOL.


DATA LV_MSG TYPE STRING.
DATA LT_MSG TYPE TABLE OF TY_MSG.
DATA GS_MSG TYPE TY_MSG.

LOOP AT GT_DATA ASSIGNING <FS_DATA>.
  CLEAR GS_DATA.
  MOVE <FS_DATA> TO GS_DATA.
  LV_POSNR = LV_POSNR + 10.

  LT_ITEMS = VALUE #( ITM_NUMBER  = LV_POSNR
                      MATERIAL    = GS_DATA-MATNR
                      PO_ITM_NO   = '000010'
                      TARGET_QTY  = GS_DATA-KWMENG
                      PLANT       = GS_DATA-WERKS
                      ITEM_CATEG  = GS_DATA-PSTYV
                       STORE_LOC   = GS_DATA-LGORT ).
  APPEND LT_ITEMS.

  LT_ITEMSX = VALUE #( ITM_NUMBER  = LV_POSNR
                       MATERIAL    = 'X'
                       PO_ITM_NO   = 'X'
                       TARGET_QTY  = 'X'
                       PLANT       = 'X'
                       ITEM_CATEG  = 'X' ).
  APPEND LT_ITEMSX.

  LT_SCHDL = VALUE #( ITM_NUMBER = LV_POSNR
                      SCHED_LINE = '0001'
                      REQ_QTY    = GS_DATA-KWMENG
                      REQ_DATE   = GS_DATA-CMTD
                      DATE_TYPE  = '1' ).
  APPEND LT_SCHDL.

  LT_SCHDLX = VALUE #(  ITM_NUMBER = LV_POSNR
                        SCHED_LINE = '0001'
                        REQ_QTY    = 'X'
                        REQ_DATE   = 'X'
                        DATE_TYPE  = 'X' ).
  APPEND LT_SCHDLX.

  LT_COND = VALUE #(  ITM_NUMBER = LV_POSNR
                      COND_ST_NO = '010'
                      COND_COUNT = '01'
                      COND_TYPE  = GS_DATA-KSCHA
                      COND_VALUE = GS_DATA-NETWR
                      COND_P_UNT = GS_DATA-KPEIN
                      CURRENCY   = GS_DATA-WAERK ).
  APPEND LT_COND.

  LT_CONDX = VALUE #( ITM_NUMBER = LV_POSNR
                      COND_ST_NO = '010'
                      COND_COUNT = '01'
                      UPDATEFLAG = 'I'
                      COND_VALUE = 'X'
                      COND_P_UNT = 'X'
                      CURRENCY   = 'X' ).
  LT_CONDX-COND_TYPE  = LT_CONDX-COND_TYPE .
  APPEND LT_CONDX.

  AT END OF ZLINE.
    "根据不同的序列号生成销售订单
    CLEAR GS_MSG.
    LS_HEADER = VALUE #(  DOC_TYPE   = GS_DATA-AUART    "销售订单类型
                          SALES_ORG  = GS_DATA-VKORG    "销售组织
                          DISTR_CHAN = GS_DATA-VTWEG    "分销渠道
                          DIVISION   = GS_DATA-SPART    "产品组
                          SALES_OFF  = GS_DATA-VKBUR    "销售办事处
                          SALES_GRP  = GS_DATA-VKGRP    "销售组
                          PURCH_NO_C = GS_DATA-BSTNK    "客户参考
                          PRICE_DATE = GS_DATA-PRSDT    "定价日期
                          PMNTTRMS   = GS_DATA-ZTERM ).  "付款条件

    LS_HEADERX = VALUE #( DOC_TYPE   = 'X'
                          SALES_ORG  = 'X'
                          DISTR_CHAN = 'X'
                          DIVISION   = 'X'
                          SALES_OFF  = 'X'
                          SALES_GRP  = 'X'
                          PURCH_NO_C = 'X'
                          PRICE_DATE = 'X'
                          PMNTTRMS   = 'X' ).

    LT_PARTNERS[] = VALUE #( ( PARTN_ROLE = 'AG' PARTN_NUMB = GS_DATA-KUNNR )
                             ( PARTN_ROLE = 'RE' PARTN_NUMB = GS_DATA-KUNWE ) ).

    BAPE_VBAK = VALUE #( ZYWY = GS_DATA-ZYWY ).
    LS_EXTENSIONIN = VALUE #( STRUCTURE = 'BAPE_VBAK' ).

    CALL METHOD CL_ABAP_CONTAINER_UTILITIES=>FILL_CONTAINER_C
      EXPORTING
        IM_VALUE               = BAPE_VBAK
      IMPORTING
        EX_CONTAINER           = LS_EXTENSIONIN-VALUEPART1
      EXCEPTIONS
        ILLEGAL_PARAMETER_TYPE = 1
        OTHERS                 = 2.
    APPEND LS_EXTENSIONIN TO LT_EXTENSIONIN.


    BAPE_VBAKX = VALUE #( ZYWY = 'X' ).
    LS_EXTENSIONIN = VALUE #( STRUCTURE = 'BAPE_VBAKX' ).

    CALL METHOD CL_ABAP_CONTAINER_UTILITIES=>FILL_CONTAINER_C
      EXPORTING
        IM_VALUE               = BAPE_VBAKX
      IMPORTING
        EX_CONTAINER           = LS_EXTENSIONIN-VALUEPART1
      EXCEPTIONS
        ILLEGAL_PARAMETER_TYPE = 1
        OTHERS                 = 2.
    APPEND LS_EXTENSIONIN TO LT_EXTENSIONIN.

    CALL FUNCTION 'BAPI_SALESORDER_CREATEFROMDAT2'
      EXPORTING
        ORDER_HEADER_IN      = LS_HEADER
        ORDER_HEADER_INX     = LS_HEADERX
      IMPORTING
        SALESDOCUMENT        = LV_VBELN
      TABLES
        RETURN               = LT_RETURN
        ORDER_ITEMS_IN       = LT_ITEMS
        ORDER_ITEMS_INX      = LT_ITEMSX
        ORDER_PARTNERS       = LT_PARTNERS
        ORDER_SCHEDULES_IN   = LT_SCHDL
        ORDER_SCHEDULES_INX  = LT_SCHDLX
        ORDER_CONDITIONS_IN  = LT_COND
        ORDER_CONDITIONS_INX = LT_CONDX
        EXTENSIONIN          = LT_EXTENSIONIN.

    LOOP AT LT_RETURN WHERE TYPE CA 'EAXI'.
      LV_FLAG = 'X'.
    ENDLOOP.

    IF LV_FLAG IS INITIAL.
      CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
        EXPORTING
          WAIT = 'X'.
      "创建成功后获取成功消息
      LOOP AT LT_RETURN WHERE TYPE EQ 'S' AND ID EQ 'V1' AND NUMBER EQ '311'.
        CALL FUNCTION 'MESSAGE_TEXT_BUILD'
          EXPORTING
            MSGID               = LT_RETURN-ID
            MSGNR               = LT_RETURN-NUMBER
            MSGV1               = LT_RETURN-MESSAGE_V1
            MSGV2               = LT_RETURN-MESSAGE_V2
            MSGV3               = LT_RETURN-MESSAGE_V3
            MSGV4               = LT_RETURN-MESSAGE_V4
          IMPORTING
            MESSAGE_TEXT_OUTPUT = LV_MSG.
        CONCATENATE LV_MSG GS_MSG-MSG INTO GS_MSG-MSG.
      ENDLOOP.

      GS_MSG-STATUS = '@5B@'.
    ELSE.
      CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.
      "回滚后获取报错原因
      LOOP AT LT_RETURN WHERE TYPE CA 'EAXI'.
        CALL FUNCTION 'MESSAGE_TEXT_BUILD'
          EXPORTING
            MSGID               = LT_RETURN-ID
            MSGNR               = LT_RETURN-NUMBER
            MSGV1               = LT_RETURN-MESSAGE_V1
            MSGV2               = LT_RETURN-MESSAGE_V2
            MSGV3               = LT_RETURN-MESSAGE_V3
            MSGV4               = LT_RETURN-MESSAGE_V4
          IMPORTING
            MESSAGE_TEXT_OUTPUT = LV_MSG.
        CONCATENATE LV_MSG GS_MSG-MSG INTO GS_MSG-MSG.
      ENDLOOP.
      GS_MSG-STATUS = '@5C@'.
    ENDIF.
    "会写销售订单号
    GS_MSG-VBELN = LV_VBELN.
    GS_MSG-ZLINE = GS_DATA-ZLINE.
    GS_MSG-LGORT = GS_DATA-LGORT.
    GS_MSG-CMTD  = GS_DATA-CMTD.
    APPEND  GS_MSG TO LT_MSG.
    CLEAR: LV_POSNR,LV_FLAG,LV_VBELN,LV_MSG,LS_HEADER,LS_HEADERX,LT_ITEMS[],LT_ITEMSX[],
           LT_PARTNERS[],LT_SCHDL[],LT_SCHDLX[],LT_COND[],LT_CONDX[],LT_EXTENSIONIN[],
           GS_MSG.
  ENDAT.
ENDLOOP.

 

这篇关于创建销售订单BAPI BAPI_SALESORDER_CREATEFROMDAT2的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/333651

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Springboot使用RabbitMQ实现关闭超时订单(示例详解)

《Springboot使用RabbitMQ实现关闭超时订单(示例详解)》介绍了如何在SpringBoot项目中使用RabbitMQ实现订单的延时处理和超时关闭,通过配置RabbitMQ的交换机、队列和... 目录1.maven中引入rabbitmq的依赖:2.application.yml中进行rabbit

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

批处理以当前时间为文件名创建文件

批处理以当前时间为文件名创建文件 批处理创建空文件 有时候,需要创建以当前时间命名的文件,手动输入当然可以,但是有更省心的方法吗? 假设我是 windows 操作系统,打开命令行。 输入以下命令试试: echo %date:~0,4%_%date:~5,2%_%date:~8,2%_%time:~0,2%_%time:~3,2%_%time:~6,2% 输出类似: 2019_06