SAP S/4HANA销售订单创建时,会自动触发生产订单的创建

简介: SAP S/4HANA销售订单创建时,会自动触发生产订单的创建

这个自动触发的过程是怎么实现的?

使用下面的代码创建一个销售订单:

DATA: ls_header         TYPE bapisdhd1,

     ls_headerx        TYPE bapisdhd1x,

     lt_bapiret2       LIKE bapiret2   OCCURS 0 WITH HEADER LINE,

     po_order_number   TYPE bapivbeln-vbeln,

     lt_partners       TYPE TABLE OF bapiparnr,

     lt_order_items_in TYPE TABLE OF bapisditm,

     lt_order_item_x   TYPE TABLE OF bapisditmx,

     ls_order_item_x   LIKE LINE OF lt_order_item_x,

     ls_order_items_in LIKE LINE OF lt_order_items_in,

     lt_schdlin        TYPE TABLE OF bapischdl,

     ls_schdlin        LIKE LINE OF lt_schdlin,

     lt_schdlinx       TYPE TABLE OF bapischdlx,

     ls_schdlinx       LIKE LINE OF lt_schdlinx,

     ls_partners       LIKE LINE OF lt_partners,

     lt_order_text TYPE TABLE OF bapisdtext,

     ls_order_text  TYPE bapisdtext.

ls_header-serv_date = '20200101'.

ls_header-doc_type = 'TA'.

ls_header-purch_no_c = 'a'.

ls_headerx-purch_no_c = 'X'.

*ls_header-sales_org = '0001'.

*ls_header-distr_chan = '01'.

*ls_header-division = '01'.

ls_header-comp_cde_b = '0001'.

ls_headerx-comp_cde_b = 'X'.

ls_headerx-doc_type = 'X'.

ls_headerx-updateflag = 'I'.

ls_partners-partn_role = 'WE'. "ship to party

ls_partners-partn_numb = '0000000001'.

APPEND ls_partners TO lt_partners.

ls_partners-partn_role = 'AG'. " sold to party

ls_partners-partn_numb = '0000000001'.

APPEND ls_partners TO lt_partners.

ls_order_items_in-item_categ = 'TAN'.

ls_order_items_in-material = 'REDUCER_A'.

ls_order_items_in-target_qty = 999.

ls_order_items_in-itm_number = 10.

ls_order_item_x-item_categ = 'X'.

ls_order_item_x-material = 'X'.

ls_order_item_x-target_qty = 'X'.

ls_order_item_x-itm_number = 'X'.

ls_order_item_x-updateflag = 'I'.

APPEND ls_order_item_x TO lt_order_item_x.

APPEND ls_order_items_in TO lt_order_items_in.

ls_schdlin-itm_number = 10.

ls_schdlin-req_qty = 3.

ls_schdlinx-itm_number = 'X'.

ls_schdlinx-itm_number = 'X'.

ls_schdlinx-updateflag = 'X'.

APPEND ls_schdlin TO lt_schdlin.

APPEND ls_schdlinx TO lt_schdlinx.

"ls_order_text-doc_number = SALESDOCUMENT.

ls_order_text-itm_number = '000010'.

ls_order_text-text_id = '0006'.

"ls_order_text-langu = 'E'.

ls_order_text-langu_iso = 'ZH'.

ls_order_text-format_col = '*'.

ls_order_text-text_line = 'Test 2 DSFSDFDSFDS'.

ls_order_text-function = '006'.

APPEND ls_order_text TO lt_order_text.

CALL FUNCTION 'SD_SALESDOCUMENT_CREATE'

 EXPORTING

   sales_header_in       = ls_header

   sales_header_inx      = ls_headerx

   int_number_assignment = 'X'

 IMPORTING

   salesdocument_ex      = po_order_number

 TABLES

   return                = lt_bapiret2

   sales_items_in        = lt_order_items_in

   sales_items_inx       = lt_order_item_x

   sales_schedules_in    = lt_schdlin

   sales_schedules_inx   = lt_schdlinx

   sales_partners        = lt_partners

   sales_text            = lt_order_text.

LOOP AT lt_bapiret2 ASSIGNING FIELD-SYMBOL() WHERE type = 'E'.

 WRITE:/ 'Error:', -message COLOR COL_NEGATIVE.

 RETURN.

ENDLOOP.

IF po_order_number IS INITIAL.

 WRITE:/ 'PO number initial'.

 RETURN.

ENDIF.

CLEAR: lt_bapiret2.

CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'

 EXPORTING

   wait   = 'X'

 IMPORTING

   return = lt_bapiret2.

LOOP AT lt_bapiret2 ASSIGNING .

 WRITE:/ 'Message:', -message COLOR COL_POSITIVE.

ENDLOOP.

用事务码SAT分析,发现总共创建消耗的时间为3.98秒,




其中1.84秒花费在EIGENFERTIGUNG_BEARBEITEN这个subroutine上。




用一下Google Translate:


发现EIGENFERTIGUNG的含义就和生产有关:own production




BEARBEITEN的意思是TO eidt:




看这个函数CO_61_ORDER_EDIT:




这个函数的描述信息指向了它是用来做生产用的:




这个函数所在的包也透露了它的作用,是负责生产相关实现的:




观察一下传入这个函数的各参数值:



目录
相关文章
|
20天前
|
开发者 数据处理 数据管理
SAP HANA 的不同类型
SAP HANA 的不同类型
36 9
SAP HANA 的不同类型
|
20天前
|
SQL 数据库 索引
关于 SAP ABAP REPOSRC 数据库表在 HANA 中的 DDL Definition
关于 SAP ABAP REPOSRC 数据库表在 HANA 中的 DDL Definition
18 1
关于 SAP ABAP REPOSRC 数据库表在 HANA 中的 DDL Definition
|
1月前
|
Linux 开发工具 开发者
关于 SAP HANA 开发那些事
关于 SAP HANA 开发那些事
24 0
|
3月前
|
SQL 存储 数据可视化
SAP HANA 内存数据库不同类型的视图的应用场景介绍
SAP HANA 内存数据库不同类型的视图的应用场景介绍
55 0
|
20天前
|
数据库 存储 监控
什么是 SAP HANA 内存数据库 的 Delta Storage
什么是 SAP HANA 内存数据库 的 Delta Storage
16 0
什么是 SAP HANA 内存数据库 的 Delta Storage
|
16天前
|
Java BI API
SAP Cloud for Customer 里如何通过 ABSL 二次开发方式消费 SAP S/4HANA 系统的 API
SAP Cloud for Customer 里如何通过 ABSL 二次开发方式消费 SAP S/4HANA 系统的 API
14 0
|
20天前
|
数据库 SQL 应用服务中间件
SAP ABAP CDS View 和 HANA CDS View 相同点和不同点辨析
SAP ABAP CDS View 和 HANA CDS View 相同点和不同点辨析
20 0
SAP ABAP CDS View 和 HANA CDS View 相同点和不同点辨析
|
3月前
|
存储 数据库
SAP HANA 数据库支持的几种不同类型的视图
SAP HANA 数据库支持的几种不同类型的视图
34 0
|
5月前
|
SQL 存储 JavaScript
SAP HANA 详细介绍
SAP HANA 详细介绍
186 0
|
6月前
|
前端开发 JavaScript 数据库
SAP S/4HANA 的 Data-Centric Applications 编程范式
SAP S/4HANA 的 Data-Centric Applications 编程范式
50 0