您好,欢迎来到刀刀网。
搜索
您的当前位置:首页SAP增强实现批次自动编号

SAP增强实现批次自动编号

来源:刀刀网


批次编号处理

批次编号范围(将采用批次管理的物料分为两种,1种是自制件(E),1种是采购件(F),对于既有自制、又有采购的,根据实际状况处理)

• 对于自制件,批次编号跟生产订单编号一致(使用出口来实现)

• 对于外购件,批次编号采用6位日期+3位流水码(使用出口来实现)

内部编号范围分配目前逻辑如下,根据物料的生产方式

• F->外购件-> 批次编号采用6位日期+3位流水号

o 对于1个物料来说,如果批次号码内部给号而不是手工输入,那么流水码从

001直到999,每次货物移动,流水码自动加1

o 对于不同的物料来说,比如之前有个物料使用了流水码180111000如果

MCH1物料+流水码查询不到记录,那么此物料仍然可以使用流水码180111000

• E->外购件-> 批次编号采用生产订单编号

• X->判断当前的生产订单编号是否为空

o 生产订单编号为空 -> 6位日期+3位流水号

o 工厂代码)

生产订单编号不为空-> 生产订单编号(生产订单编号采用10位,前两位为

首先对于增强说一下我的理解:

用户出口SAPLV01Z是用户自动分配批次号码(内部给号的),并且只有在配置了

基于移动类型生成新批次,并且设置成B,此出口才会被触发,所有的配置B的移动类型,在用MIGO进行货物移动时,都会触发增强的逻辑,并且增强逻辑只对(没有输入批次号码)这种情况下才生效。

集团配置的自动创建批次移动类型为101、103、501

对于批次,整个集团的规则是,批次号码均是自动生成,只有特殊情况才可以手工输入(561初始化,以及盘盈701、711):

只有收货(101、103、501-仅限采购件),才能自动产生新批次(设置成B-Automatic/Manual

and check in USER EXIT),其他的移动类型都要设成G-no creation

对于消耗的移动类型(201、261、281、601、541、543)批次都是根据批次确定规则(FIFO&剩余货架寿命),自动排出批次(在migo里面也要配置增强,如果输入的批次号不在MCH1或者MCHA中,会报错),且不允许产生新批次->全部设成G-no creation,且需要配置批次确定规则

对于移库类(241/242、301/302、303/304、305/306、309/310、311/312、313/314、315/316、344/343、411/412、413/414、415/416、551/552。。)如果物料有用到批次管理,会检查输入的批次是否存在,如果不存在,会报错,也是在MIGO增强里面做检查,因为移库可能没法使用FIFO规则。且不允许产生新批次->全部设成G-no creation,且不需要配置批次确定规则

对于561,并不设置内部检查规则(即采用默认配置),对于561初始化库存时,批次可以手工输入

对于701(盘盈),理论上,所有的盘盈并不会产生新批次,如果真的产生新批次的物料,批次可以手工输入,即701也采用默认配置

CMOD创建增强项目

注:EXIT_SAPLV01Z_001 & EXIT_SAPLV01Z_002适用于内部给号的情况

对出口EXIT_SAPLV01Z_002加代码

源代码

*&---------------------------------------------------------------------*

*& Include ZXVBZU02

*& 内部编号范围分配目前逻辑如下

*& 根据物料的生产方式

*& F->外购件-> 批次编号采用6位日期+3位流水号

*& 流水号含义->对于1个物料来说,如果批次号码内部给号而不是手工输入,那么流水码从001直到999,

*& 每次货物移动,流水码自动加1

*& ->对于不同的物料来说,比如之前有个物料使用了流水码180111001如果MCH1物料+流水码

*& 查询不到记录,那么此物料仍然可以使用流水码180111001

*& E->外购件-> 批次编号采用生产订单编号

*& X->判断当前的生产订单编号是否为空

*& 生产订单编号为空 -> 6位日期+3位流水号

*& 生产订单编号不为空-> 生产订单编号

*&---------------------------------------------------------------------*

TABLES:zbatch,mch1,marc.

DATA tab01 LIKE TABLE OF zbatch WITH HEADER LINE.

DATA batch_number TYPE mch1-charg.

DATA pre_flow_number(3) TYPE n. \"前一个流水号

DATA cur_flow_number(3) TYPE n. \"当前流水号

DATA zbeskz TYPE marc-beskz. \"采购方式

CLEAR batch_number. \"批次号码

CLEAR pre_flow_number.

CLEAR cur_flow_number.

CLEAR tab01.

\"首先获取物料的采购方式

SELECT SINGLE marc~beskz INTO zbeskz FROM marc

WHERE marc~werks = x_bncom-werks

AND marc~matnr = x_bncom-matnr.

\"首先获取当前日期,当前物料下,该物料的最大批次号

CASE zbeskz.

WHEN 'F'. \"外购件,使用流水码的批次号

SELECT MAX( charg ) INTO batch_number FROM MCH1 WHERE matnr = x_bncom-matnr AND ERSDA = sy-datum.

IF batch_number IS INITIAL. \"如果当天的批次号不存在,那么当前流水号

为001

cur_flow_number = '001'.

ELSE.

pre_flow_number = batch_number+6(3). \"如果当天的批次存在,那么前一个流水号=取到的流水号

cur_flow_number = pre_flow_number + 1. \"当前流水号=前一个流水号+1

ENDIF.

\"将此次的批次信息插入到表ZBATCH中

CONCATENATE sy-datum+2(6) cur_flow_number INTO batch_number. \"当前日期后6位+当前流水号作为当前的批次号码

WHEN 'E'.

IF x_bncom-bwart <> '101' or x_bncom-bwart <> '103'.

MESSAGE e001(00) WITH 'Please input batch number!'.

ELSE.

batch_number = x_bncom-aufnr.

ENDIF.

WHEN 'X'.

IF x_bncom-aufnr IS INITIAL.

SELECT MAX( charg ) INTO batch_number FROM zbatch WHERE matnr = x_bncom-matnr AND cdate = sy-datum.

IF batch_number IS INITIAL. \"如果当天的批次号不存在,那么当前流水号为001

cur_flow_number = '001'.

ELSE.

pre_flow_number = batch_number+6(3). \"如果当天的批次存在,那么前一个流水号=取到的流水号

cur_flow_number = pre_flow_number + 1. \"当前流水号=前一个流水号+1

ENDIF.

\"将此次的批次信息插入到表ZBATCH中

CONCATENATE sy-datum+2(6) cur_flow_number INTO batch_number. \"当前日期后6位+当前流水号作为当前的批次号码

ELSE.

IF x_bncom-bwart <> '101' or x_bncom-bwart <> '103'.

MESSAGE e001(00) WITH 'Please input batch number! Finished Goods auto batch numer only allowed for mvt 101'.

ELSE.

batch_number = x_bncom-aufnr.

ENDIF.

ENDIF.

ENDCASE.

* tab01-charg = batch_number.

* tab01-matnr = x_bncom-matnr.

* tab01-cdate = sy-datum.

* tab01-werks = x_bncom-werks.

* APPEND tab01.

*

* IF sy-ucomm = 'OK_POST1'. \"只有post才会将数据写入到表ZBATCH中

* INSERT zbatch FROM tab01.

* COMMIT WORK.

* ENDIF.

new_charg = batch_number.

测试验证:

采购件

根据当前系统日期带出批次编号,测试通过

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- gamedaodao.com 版权所有 湘ICP备2022005869号-6

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务