创建生产订单,创建订单长文本,订单下达

DATA:gs_bapi_pp_order_create TYPE bapi_pp_order_create.
DATA:gt_bapi_order_key TYPE TABLE OF bapi_order_key,
gs_bapi_order_key TYPE bapi_order_key,
gt_order_return TYPE TABLE OF bapi_order_return WITH HEADER LINE.
DATA:gs_return TYPE bapiret2,
gt_return TYPE bssp_t_message,
gw_return TYPE bssp_s_message,
gv_order_number TYPE bapi_order_key-order_number.
DATA:gt_tline TYPE TABLE OF tline,
gw_tline TYPE tline.
CLEAR:gt_return[],gs_return.
DATA:gs_keko TYPE keko.
DATA:gv_message TYPE string. DATA:lv_int TYPE i.
DATA:g_fname TYPE thead-tdname.
CLEAR:lv_int.
LOOP AT gt_zstybcp INTO gw_zstybcp WHERE sel = 'X' AND aufnr = ''.
lv_int = lv_int + .
"add by ly 20151124
SELECT SINGLE * INTO CORRESPONDING FIELDS OF gs_keko
FROM keko WHERE matnr = gw_zstybcp-matnr
AND werks = gw_zstybcp-werks
AND bwkey = gw_zstybcp-werks
AND kadat LE sy-datum
AND bidat GE sy-datum
AND freig = 'X'.
IF sy-subrc <> .
gv_message = gv_message && ' ' && gw_zstybcp-matnr.
* MESSAGE '物料' && gw_zstybcp-matnr && '请先下达标准成本估算!' TYPE 'S' DISPLAY LIKE 'E'.
EXIT.
ENDIF.
"add by ly 20151124
ENDLOOP.
"仅限选择一行,且选择行中的办成品油已生成生产订单,直接调用T-code 到修改界面 IF gv_message IS INITIAL.
ELSE.
MESSAGE '物料' && gv_message && '未下达标准成本估算!' TYPE 'S' DISPLAY LIKE 'E'.
EXIT.
ENDIF. IF lv_int <> . ELSE.
MESSAGE '请选择调油半成品生产订单为空的行项目!' TYPE 'S' DISPLAY LIKE 'E'.
EXIT.
ENDIF.
* PERFORM PRM_DATA_CHECK.
LOOP AT gt_zstybcp INTO gw_zstybcp WHERE sel = 'X' AND aufnr = ''."ADD BY 20150716 LY FOR 批量创建
CLEAR:gs_return,gw_return,gt_order_return[],gt_bapi_order_key[],gs_bapi_order_key.
gs_bapi_pp_order_create-material = gw_zstybcp-matnr."订单物料号
gs_bapi_pp_order_create-plant = gw_zstybcp-werks."订单工厂
gs_bapi_pp_order_create-planning_plant = gw_zstybcp-werks."计划工厂
gs_bapi_pp_order_create-basic_start_date = gw_zstybcp-gstrp."基础开始日期
gs_bapi_pp_order_create-basic_end_date = gw_zstybcp-gstrp."基准解释日期
gs_bapi_pp_order_create-quantity = gw_zstybcp-bdmng."订单数量
CALL FUNCTION 'CONVERSION_EXIT_CUNIT_INPUT' "单位
EXPORTING
input = gw_zstybcp-meins
* LANGUAGE = SY-LANGU
IMPORTING
output = gs_bapi_pp_order_create-quantity_uom
EXCEPTIONS
unit_not_found =
OTHERS = .
IF sy-subrc <> .
ENDIF. * GS_BAPI_PP_ORDER_CREATE-QUANTITY_UOM = GW_ZSTYBCP-MEINS."单位
gs_bapi_pp_order_create-goods_recipient = gw_zstybcp-wempf."收货方
* GS_BAPI_PP_ORDER_CREATE-GOODS_RECIPIENT = GW_ZSTYBCP-MEINS.
gs_bapi_pp_order_create-order_type = 'DL02'.
"调用订单创建函数创建调油半成品生产订单
CALL FUNCTION 'BAPI_PRODORD_CREATE'
EXPORTING
orderdata = gs_bapi_pp_order_create
IMPORTING
return = gs_return
order_number = gv_order_number. IF gs_return-type IS NOT INITIAL."消息填表
gw_return-msgid = gs_return-id.
gw_return-msgty = gs_return-type.
gw_return-msgno = gs_return-number.
gw_return-msgv1 = gs_return-message_v1.
gw_return-msgv2 = gs_return-message_v2.
gw_return-msgv3 = gs_return-message_v3.
gw_return-msgv4 = gs_return-message_v4.
APPEND gw_return TO gt_return.
ENDIF.
* APPEND GS_RETURN TO GT_RETURN."消息填表 IF gs_return-type = 'E' OR gs_return = 'A'.
* CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.
gw_zstybcp-icon = '@OA@'.
gw_zstybcp-message = gs_return-message.
ELSE.
* CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
* EXPORTING
* wait = 'X'.
gw_zstybcp-icon = '@08@'.
gw_zstybcp-message = '成功创建调油半成品生产订单'.
gw_zstybcp-aufnr = gv_order_number.
gw_zstybcp-psmng = gw_zstybcp-bdmng.
gw_zstybcp-amein = gw_zstybcp-meins. CONCATENATE sy-mandt gv_order_number INTO g_fname.
gw_tline-tdformat = .
gw_tline-tdline = gw_zstybcp-ztiay.
APPEND gw_tline TO gt_tline. CALL FUNCTION 'CREATE_TEXT'
EXPORTING
fid = 'KOPF'
flanguage = sy-langu
fname = g_fname
fobject = 'AUFK'
TABLES
flines = gt_tline
EXCEPTIONS
no_init =
no_save =
OTHERS = .
IF sy-subrc <> .
ENDIF.
IF sy-subrc = .
CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
EXPORTING
wait = 'X'.
ELSE.
CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'. ENDIF. WAIT UP TO SECONDS.
UPDATE aufk SET ltext = '' WHERE aufnr = gv_order_number.
COMMIT WORK. gs_bapi_order_key-order_number = gv_order_number.
APPEND gs_bapi_order_key TO gt_bapi_order_key. "ADD BY LY 20150610订单下达
CALL FUNCTION 'BAPI_PRODORD_RELEASE'
* EXPORTING
* RELEASE_CONTROL = '1'
* WORK_PROCESS_GROUP = 'COWORK_BAPI'
* WORK_PROCESS_MAX = 99
* IMPORTING
* RETURN =
TABLES
orders = gt_bapi_order_key
detail_return = gt_order_return.
READ TABLE gt_order_return WITH KEY type = 'E'.
IF sy-subrc <> .
* CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
* EXPORTING
* wait = 'X'.
ELSE.
* CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'. CONCATENATE '订单' gv_order_number '下达失败,请手动下达!' INTO gw_return-msgv1.
MESSAGE gw_return-msgv1 TYPE 'S' DISPLAY LIKE 'E'.
ENDIF. ENDIF.
MODIFY gt_zstybcp FROM gw_zstybcp.
ENDLOOP. * IF GT_RETURN[] IS NOT INITIAL."消息显示
* CALL FUNCTION 'BSSP2_MESSAGE_POPUP'
* EXPORTING
* IT_MESSAGE = GT_RETURN
* IF_SAVE_NECESSARY = ''.
* ENDIF.

创建生产订单函数BAPI_PRODORD_CREATE的更多相关文章

  1. ABAP 生产订单的创建与修改函数

    ABAP 生产订单的创建与修改函数转自http://www.cnblogs.com/aBaoRong/archive/2012/04/11/2441946.html   如果生产订单过多,可以批量创建 ...

  2. PP生产订单创建、下达、报工、收货、投料

    转自http://blog.sina.com.cn/s/blog_69fb8eb60102vpjd.html SAP 物料订单创建.下达.报工.收货与投料(ABAP代码) (2015-06-03 22 ...

  3. 物料BOM和生产订单BOM的区别

    物料BOM和生产订单BOM的区别[@more@] 一般企业生产部在SAP创建生产订单的时候,就会产生一个生产订单BOM,这里的生产订单BOM是读取的物料BOM. 由于其它原因,需要修改成品的某几个零部 ...

  4. SAP S/4HANA生产订单的BAdI增强点之Initialize方法

    在S/4HANA里创建生产订单时,有一个增强点WORKORDER_UPDATE: 这个CAUFVDB里存放的是生产订单抬头级别的数据: 我们来观察下运行时这个结构里存放的数据. 请大家用我github ...

  5. 为什么S/4HANA的生产订单创建后会自动release

    在S/4HANA系统里我们观察到通过函数CO_61_ORDER_EDIT创建的生产订单会自动释放Release: 通过第86行的IF语句的条件检测不难找到原因. 变量PROFILE_TMP的类型为TC ...

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

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

  7. SAP S/4HANA生产订单创建时使用的工厂数据是从什么地方带出来的

    大家如果使用我github上的这段代码创建S/4HANA的生产订单时,一定会发现,我在代码里并没有硬编码来指定生产订单的ID,然而运行时会发现我在系统里配置的这个2800被自动使用了,这是怎么做到的呢 ...

  8. PP-判断生产订单状态(关闭)

    方法一.工单号通过 resb找到对象号 然后找到状态为I0045利用表JEST与TJ02T . 方法二.函数'STATU_CHECK' 检查工单状态为'I0045' 则为已做技术性关闭. READ T ...

  9. 增强篇4 CO01生产订单屏幕增强

    Step1. 结构 CO_AUFK 里增加自定义字段:ZZZ_TRIAL 然后激活结构 查看AUFK是激活状态, 字段增强完成: Step2. CMOD  使用客户增强:PPCO0012    生产订 ...

随机推荐

  1. [HDOJ5950]Recursive sequence(递推,二项展开,矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5950 题意:求解递推式f(n)=f(n-1)+2*f(n-2)+n^4. 写了个小东西,不过我的文章里 ...

  2. Berkeley DB的常见API简单分析

    1.用来存储类信息的数据库不要求能够存储重复的关键字    例:    dbConfig.setSortedDuplicates(false);2.DatabaseEntrt能够支持任何能够转化为by ...

  3. SQL——存储过程实例 循环

    --循环 create or replace procedure p_xunhuan(input in number,output out number) is ); begin ; ..input ...

  4. python_way ,day9 socket 和soctet多线程的使用

    1.socket的基础 tcp/ip tcp ip 协议是主机接入互联网以及接入互联网互联两台主机通信互联标准     物理层:传输二进制 链路层:对二进制数进行分组  ,唯一标示一台主机       ...

  5. iOS - OC 面向对象语法

    1.类 1)根类:因为类 NSObject 是层次结构的最顶层,因此称为根类. 可以将类称为子类(subclass)和父类(superclass),也可以将类称为子类和超类. 2)分类/类别(cate ...

  6. LotteryDrawing

    import java.util.*; public class MyTest{ public static void main(String[] args){ Scanner in = new Sc ...

  7. bootstrap学习笔记<五>(表单一)

    表单 bootstrap为表单提供三种样式:默认表单,水平表单,内联表单. <form class="form-horizontal" role="form&quo ...

  8. mysql 循环控制

    1.使用whileDROP PROCEDURE IF EXISTS `addstudent`;DELIMITER ;;CREATE PROCEDURE `addstudent`(iNum int)BE ...

  9. XMLHttpRequest对象进行Ajax操作

    XMLHttpRequest 对象的三个常用的属性: 1. onreadystatechange 属性  onreadystatechange 属性存有处理服务器响应的函数. 请求状态改变的事件触发器 ...

  10. Vsftpd服务的搭建

    安装vsftpd服务程序 yum install vsftpd -y Vsftpd的程序与配置文件: 主程序 /usr/sbin/vsftpd 用户禁止登陆列表 /etc/vsftpd/ftpuser ...