Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1475267
  • 博文数量: 931
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 10198
  • 用 户 组: 普通用户
  • 注册时间: 2011-07-08 12:28
个人简介

测试

文章分类

全部博文(931)

文章存档

2020年(134)

2019年(792)

2018年(5)

我的朋友

分类: 架构设计与优化

2019-05-09 16:45:12

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

通过阅读SAP S/4HANA有关生产订单的标准代码发现,生产订单使用的plant工厂数据来自表VBAP的字段WERKS。

FV45EFMA_

VBAP正是销售订单的行项目表。

问题就转化为这个2800和销售订单行项目的关系。

这个2800来自结构体KUWEV的字段DWERK Delivering Plant:Ship-to Party's View of the Customer Master Record

FV45PF0K_KOMKG_KOMPG_FUELLEN,第45行。

第32行重要的函数 RV_CUSTOMER_MATERIAL_READ

DA_KUNNR:这个字段存放的是我代码里硬编码的这个客户ID:

VBAK-VKORG:VBAK-VKORG

VTWEG: distribution channel

SPART: division

然后通过函数LOCATION_ISS_PLANT_DETERMINE决定出plant:

从这里能看出这个plant来自客户主数据的ship to 视图:

kuwev KUWEV-DWERK

kuwev的值从哪里来?

从KNVV的字段VWERK里来:

knvv是客户主数据的Sales data存储表:

如何查看S/4HANA里的客户主数据的Sales相关数据?

事务码BP:

根据客户ID搜索之后,在明细页面里将Display in BP role的下拉菜单宣称FLCU01 Customer:

点这个Sales and distribution按钮:

2800就维护在这里的:

要获取更多Jerry的原创文章,请关注公众号"汪子熙":

阅读(755) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~