ME51N, ME52N 创建采购申请的一个BADI
ME51N ME52N创建修改采购申请时的一个BADI
(2013-07-11 16:50:58)
显示参数
双击进入im_header
一般都会有get_data.此处还有个get_tiems
打开参数
双击查看该结构
就是想要的采购申请号和行项目号,不过描述是:last
item number
说明是一条数据,而不是个表
注意看看后面的描述
然后看get_items,一般情况这两个方法是常用的
会发现re_itmes是
个内表
而且这个内表参考类型,是个类IF_PURCHASE_REQUISITION_ITEM
一般也会有get_data.
一层层跟下去,调用的时候定义类对象,调用其方法即可
另外:ME53N查看时,点编辑按钮,进入编辑状态,可以在ME_PROCESS_REQ_CUST --
open方法中写逻辑
FM内代码:
FUNCTION zlm_fm_me52n.
*"----------------------------------------------------------------------
*"*"Local interface:
*" IMPORTING
*" VALUE(IM_HEADER) TYPE REF TO IF_PURCHASE_REQUISITION
OPTIONAL
*" EXPORTING
*" VALUE(E_ITEM_DATA) TYPE MEREQ_ITEM
*" EXCEPTIONS
*" ERROR
*"----------------------------------------------------------------------
*"*"Local interface:
*" IMPORTING
*" VALUE(IM_HEADER) TYPE REF TO IF_PURCHASE_REQUISITION
OPTIONAL
*
*1、 通过Tcode:ME52N进行采购申请修改时,
* 更改行项目物料编码保存时需判断已更换物料是否未冻结物料,
* 如果为冻结物料,则禁止采购申请保存并给与错误提示:行项目XXX新更换物料XXXXXXX已冻结,请选择其他物料。
*2、 冻结物料判断逻辑如下:
* 当物料主数据MARA-MATNR的跨工厂物料状态MARA-MSTAE为非空时表示该物料已经冻结;
* 当物料主数据MARA-MATNR的MARA-LVORM字段为“X”表示该物料已删除
*"----------------------------------------------------------------------
DATA: wa_head TYPE mereq_header.
"表头数据:采购申请号等
DATA: it_item TYPE mmpur_requisition_items.
"行项目表:采购申请下各行项目
DATA wa_item LIKE LINE OF it_item.
"行项目工作区
DATA cl_item TYPE REF TO
if_purchase_requisition_item. "获取行项目数据的类
DATA l_item_data TYPE mereq_item.
"行项目中具体值
DATA: l_matnr TYPE matnr.
DATA:
BEGIN OF str_dongjie,
mstae TYPE mstae,
lvorm TYPE lvorm,
END OF str_dongjie,
wa_dongjie LIKE str_dongjie.
"获取头数据
CALL METHOD im_header->get_data
RECEIVING
re_data = wa_head.
"如果不是ME52N进入,没有采购申请单号,采购申请单号第一位是‘#’,不需要进行后续校验
IF wa_head-banfn(1) = '#'.
RETURN.
ENDIF.
"获取行项目
CALL METHOD im_header->get_items
RECEIVING
re_items = it_item.
"解析行项目
LOOP AT it_item INTO wa_item.
"获取行项目数据的类
cl_item = wa_item-item.
"获取行项目值
CALL METHOD cl_item->get_data
RECEIVING
re_data = l_item_data.
CLEAR l_matnr.
"获取采购申请物料号
SELECT SINGLE matnr
FROM eban
INTO l_matnr
WHERE banfn = wa_head-banfn AND
bnfpo = l_item_data-bnfpo.
"如果修改了物料,检查更新的物料是否被冻结,冻结则输出物料信息、抛出异常并退出
IF l_item_data-matnr <> l_matnr.
SELECT SINGLE mstae lvorm
INTO wa_dongjie
FROM mara
WHERE matnr = l_item_data-matnr.
IF sy-subrc = 0 AND ( wa_dongjie-mstae IS NOT INITIAL OR
wa_dongjie-lvorm = 'X' ) .
e_item_data = l_item_data.
RAISE error.
RETURN.
ENDIF.
ENDIF.
ENDLOOP.
ENDFUNCTION.
ME51N, ME52N 创建采购申请的一个BADI的更多相关文章
- 【ABAP系列】SAP ABAP BAPI_REQUISITION_CREATE创建采购申请
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP BAPI_RE ...
- SAP MM 无料号采购申请单中'评估价格'之填写
SAP MM 无料号采购申请单中'评估价格'之填写 1),SAP系统中,采购申请里的'评估价格'来源有二, a)如果是有物料号的采购,则该价格来自于物料主数据里里的成本价(移动平均价或者标准价),自动 ...
- [转载]ME51n,ME52n,ME53n屏幕增强
原文地址:ME51n,ME52n,ME53n屏幕增强作者:cyzhang811 http://blog.sina.com.cn/s/blog_721b218c0100zch9.html 使用增强:ME ...
- SAP MM已经转成PO的采购申请Item依旧可以被删除?
SAP MM已经转成PO的采购申请Item依旧可以被删除? 笔者测试发现,我们可以删除已产生PO的PR item, 系统只是给一个警告信息,不阻止保存. Purchase orders already ...
- 详解EBS接口开发之采购申请导入
更多内容可以参考我的博客 详解EBS接口开发之采购订单导入 http://blog.csdn.net/cai_xingyun/article/details/17114697 /*+++++++ ...
- SAP MM 根据采购订单反查采购申请?
SAP MM 根据采购订单反查采购申请? 前日微信上某同行发来一个message,说是想知道如何通过采购订单号查询到其前端的采购申请号. 笔者首先想到去检查采购订单相关的常用报表ME2L/ME2M/M ...
- 函数使用二:采购申请BAPI_PR_CREATE
REPORT YTEST01. ***************************采购申请创建*****************************begin DATA:LV_BANFN TY ...
- ABAP-增强-MRP运行-根据工厂/父件/子件/供应商拆分采购申请
最近有个业务需要,MRP运行过程中需要根据生产计划订单/子件/供应商对应关系来拆解采购申请. 1.具体实例: a.基础数据 整车物料:NL1G58420151001219 子件:00000000888 ...
- 从0系统学Android--1.3创建你的第一个 Android 项目
1.3 创建你的第一个 Android 项目 环境搭建完成后,我们就可以写下我们的第一个项目了. 1.3.1 创建 HelloWorld 项目 在 Android Studio 的欢迎页面点击 Sta ...
随机推荐
- 怎样去主动拿一个锁并占有?synchronized关键字即可
怎样主动去拿一个?synchronized关键字即可 怎样去释放一个锁呢?要求锁对象主动释放,打乱占有当前锁的线程即可
- shell实践--shell内嵌指令实现查看上线时间
实践小点子: 1. 做一个shell 内嵌指令例如:ls,cd,pwd这样 就实现查看上线多久: 解决办法有两种: 1) 利用脚本,如新指令为look;利用别名的方法,将look.sh脚本 ...
- many-to-one多对一属性说明
通过many-to-one元素,可以定义一种常见的与另一个持久化类的关联. 这种关系模型是多对一关联(实际上是一个对象引用-译注):这个表的一个外键引用目标表的 主键字段. <many-to-o ...
- C# 的概念
1,C#-ASP.NET C# 的概念 2,Intro ASP.NET 一,基本概念: 1,C#--语言 microsoft 开发的纯面向对象的语言,是VS2005的主流开发语言. 语言的发展 C-- ...
- 社区管理有捷径!Wish3D Earth社区网格化管理案例重磅上线
社区网格化是精细化.全覆盖.高效率的社区管理模式,便捷有效的社区网格化管理平台是社区网格化管理的关键. Wish3D Earth全新上线三维社区网格化管理平台,使用实景三维模型作为地图,地形地貌真实展 ...
- oracle如何获得新插入记录的id
.对于提交(最后一次操作commit了)的话可以查询那个提交段 SELECT 列名1,列名2…… FROM 表名 VERSIONS BETWEEN TIMESTAMP MINVALUE AND MAX ...
- 使用assembly将maven项目pom.xml中的jar包打包
参考官方网站:http://maven.apache.org/plugins/maven-assembly-plugin/usage.html 方法一:将pom.xml引入的jar包打到zip文件夹中 ...
- Linux后台进程管理(转)
fg.bg.jobs.&.ctrl + z命令一. &加在一个命令的最后,可以把这个命令放到后台执行 ,如gftp &,二.ctrl + z可以将一个正在前台执行的命令放到后台 ...
- css样式表可以被嵌入网页里面吗?
我们一般听说的是:javascript可以被嵌入到网页任何地方? 而我们一直忽略了css也可以嵌入到网页任何地方 不过,建议这种方式少写,为了浏览器的渲染速度,但对于行内样式来说,这种方式还是比较有效 ...
- SharePoint 2013 和 SharePoint 2010 功能对比
微软的网站找东西太麻烦了,在这记录一下. 从 SharePoint 2010 更改为 SharePoint 2013 http://technet.microsoft.com/zh-cn/librar ...