• SAP 常用业务数据表设计


    表的要求
    表中使用的字段请尽量参照各模块的SAP字段标准使用习惯;
      例:"ZXSLRZX销售组织对应的利润中心"中的销售组织应该使用VKORG、利润中心应该使用PRCTR。
    根据表的用途,需确定是否属于配置目的、还是业务目的。
    配置表的建议:
    需要加入MANDT字段
      例: "ZQJQD缺件清单"就没有MANDT字段
    需提供相应的维护视图;
    例:如ZCHECK_MM01工厂和利润中心的对应
    为保证DEV/QAS/PRD系统的一致性,不应该对配置表提供批量维护的功能,而应该走Request传输流程;
    例: "ZMM_GSJJGLJ公司间物料转卖价格逻辑"就是一个失败的开发案例。
    若有必要,可激活日志功能,便于对配置的更改查询;
    在定义表的时候,请不要偷懒使用"预定义数据类型"这种方式;
    业务表的建议:
    若无特殊目的,也请加入MANDT字段
    在定义关键字段的时候,请务必慎重,在理解业务需求的前提下,合理设置;(数据存在后,关键自动的变更存在较大风险)
    为减少系统存储空间,一般不需要激活更改日志;
    在定义表的时候,请不要偷懒使用"预定义数据类型"这种方式;
    程序的要求
    程序的选择屏幕,如果需要提供缺省值,请尽量通过Memory ID的方式实现,不要使用硬代码。
       例:"ZPOOIS采购订单信息报表"中的公司代码(BUK)、工厂(WRK)。
    程序的选择屏幕上的选择文本,如果属于标准字段,若无特殊需求,请尽量使用Dictionary,避免造成在不同环境中显示错误的情况。
       例:ZPOOIS的选择屏幕在英文环境下完全错误,而ZJSJSNEW就相对正确。
    程序变式(选择变式、输出变式)的灵活使用
    ALV报表,请提供变式功能(IS_VARIANT ,I_SAVE等变量);
       例: ZPOOIS的输出格式就无法保存 。
    二次开发程序中定义的自定义表,需考虑相应数据的删除及归档策略,并应该对数据量的大小有合理的估计。
    金额,请考虑币别;数量,请考虑计量单位;
     • 公司代码与工厂的关系
    一个工厂只能属于一个公司代码;
    例:3110起重机工厂只能属于3011公司代码。
    表:T001K,其中的BWKEY就是指工厂,完全等同于T001W的WERKS;
     • 公司代码与利润中心的关系
    SAP是允许一个利润中心属于多个公司代码的,但是,我们实际业务上一个利润中心通常只应该对应一个公司代码(有部分特例!)
    一个公司代码下,可以存在多个利润中心;
    例:在2001公司代码下,存在LR2180/LR2170/LR2160等多个利润中心;
    表:CEPC_BUKRS分配利润中心至公司代码
     • 工厂与利润中心的关系
     工厂跟利润中心按照SAP的本身逻辑是没有关系的;
     但为了保证业务的正确性,我们创建了表ZCHECK_MM01(工厂和利润中心的对应)来进行检查(如在物料主数据创建的时候进行检查)。
     • 工厂与库存地点的关系
    库存地点必须跟工厂一起才有意义,牢记"工厂+库存地点"!
    在不同的工厂下虽然可以存在同样的库存地点代码,但本质上是有区别的;
    T001L,工厂+库存地点
     • WM仓库与库存地点的关系
    一个仓库可以包括多个"工厂+库存地点",一个"工厂+库存地点"只能属于一个仓库;
     T320,工厂+库存地点=>仓库号
     • 销售组织与公司代码的关系
    一个销售组织只能属于一个公司代码;
    例:3011宁乡起重机销售组织只能属于3011公司代码。
    表: TVKO销售组织;
     •  销售组织与工厂的关系
     销售组织与工厂是多对多的关系,但是该关系仅说明了销售组织可以"销售"哪些工厂的,并不能表示两者之间有财务上的所属关系;
     表: TVKWZ 每个销售机构允许的工厂数
     • 采购组织与公司代码的关系
    采购组织与公司代码可以不存在分配关系,我们除极少的两三家公司外,基本上没有进行分配(如果进行分配的话,则一个采购组织只能分配给一个公司代码)。
    表:T024E 采购组织
     • 采购组织与工厂的关系
     采购组织与工厂是多对多的关系(但是如果采购组织已经分配给公司代码后,则只能分配该公司代码下的工厂给采购组织)
    T024W工厂的有效采购组织
     • 不能根据字段在前台所属的物料视图来确定相应的数据表,一定要使用F1->技术信息;
        例:采购视图的"采购价值代码"就是属于基本数据(MARA-EKWSL)。
     •  物料主数据的关键表:
     MARA,基本视图
     MARC,工厂
     MARD,工厂/库存地点
     MBEW,财务数据,其中的MBEW-BWKEY就是指工厂MARC-WERKS
     MVKE,销售组织/分销渠道
     MLGN,仓库
     MLGT,仓库/存储类型
     MSTA,物料主数据维护状态
     •  BOM主数据
     BOM用途:1表示生产
     BOM类别:M表示物料BOM
     MAST,BOM 链接物料
     STKO,BOM表头
     STPO,BOM 项目
     STZU,永久 BOM 数据
     STAS,BOMs - 项选择
     • 工艺路线主数据
    任务清单类型:N表示工艺路线、Q表示检验计划
     MAPL,分配任务清单到物料
     PLKO,任务清单 - 表头
     PLFL,任务清单 - 顺序
     PLPO,任务清单 - 工序/作业
     PLAS,任务清单 - 工序/作业选择
     PLMZ,组件分配
     CRHD,工作中心
     • 独立需求
     PBIM,物料的独立需求
     PBED,独立需求数据
     PBID,独立需求数据(MRP区域)
     PBHI ,独立需求历史记录
     • 计划订单
     PLAF,计划订单,需注意计划工厂PLWRK、生产工厂PWWRK的区别;
     RESB,预留表(通过PLAF-RSNUM与RESB-RSNUM关联)
     • 生产订单
     订单类别: AUTYP,10表示生产订单
     AUFK,订单主数据
      其中WERKS 工厂是指生产订单的生产工厂、 LOEKZ删除标记是对删除状态的生产订单生效(其他状态需通过JEST)进行读取。
     AFKO,订单表头数据 PP 订单
      其中PLNBEZ 、STLBEZ并不一定是订单中产出物料(真正的物料应该是AFPO-MATNR)。
     AFPO,订单项
      虽然关键字中存在POSNR,但实际上我们不存在co-product业务,所以POSNR都为0001.
     AFVC,订单的工序(通过AFKO- AUFPL进行关联)
     AFVV,工序中数量/日期/值的DB结构
     AFFL,加工单顺序
     JEST,订单状态(通过AUFK-OBJNR关联)
     其中STAT的具体含义通过TJ02T对应,注意当INACT=X时,表示该状态不存在。
     RESB,预留表(通过AFKO-RSNUM与RESB-RSNUM关联)
     • 报工/入库/发料
     AFRU,订单确认(AFRU-AUFNR为订单号)
     AFFW,COGI错误(AFFW-AUFNR为订单号)
    由于我们没有激活COGI更改历史,所以COGI的更改在AFFWPRO中是没有记录的,若有必要,可通过自定义备份表ZAFFWH进行查看。
      AUFM,订单物料移动数据(AUFM-AUFNR为订单号)
    该表的数据更新需依赖于PP的相关配置。此外,如果需要得到某一预留的累计发料数量,可直接使用RESB-ENMNG;如果需要得到某一订单的累计入库数量,可直接使用AFPO-WEMNG。均不需要对物料移动数据进行累加。
     • 供应商主数据
     LFA1,集团数据
     ADRC,地址信息
     LFB1,公司代码数据
     LFM1,采购组织数据
     • 计划订单
     PLAF,计划订单;
     • 采购合同
    凭证类别(EKKO-BSTYP)等于K(合同)
     EKKO,采购凭证抬头
     EKPO,采购凭证项目
     • 采购信息记录
     信息记录类别(EINE-ESOKZ):0(标准)、 2(寄售)、3(分包合同)
     EINA ,采购信息记录 - 一般数据
     EINE ,采购信息记录 - 采购组织数据
     • 采购申请
     EBAN,采购申请
     • 采购订单
     凭证类别(EKKO-BSTYP)等于F(采购订单)
     关键表:
     EKKO,采购凭证抬头
     EKPO,采购凭证项目
     EKET,计划协议计划行
     EKKN,采购凭证中的帐户设置
     • 采购收货及发票校验
     EKBE,采购凭证历史
     如果需要得到某一采购订单行项目的累计入库数量,可直接使用EKET-WEMNG,不需要对物料移动数据进行累加。 (虽然SAP是允许同一采购订单行项目是允许多个交货计划(EKET),但我们实际上业务中只允许一个交货计划,很多开发和考核都是基于此)
     RBKP,凭证表头:发票收据
     RSEG,凭证项目:收款发票
     通过发票凭证读取会计凭证建议使用函数AC_DOCUMENT_RECORD。
     • 仓位主数据
     仓位必须跟仓库号、仓储类型一起才有意义,牢记"仓库号+仓储类型+仓位"!
     关键表:
     LAGP,仓位
     • 库存数据
     IM库存数据(注意使用待H的数据):
     MARD,物料的仓储位置数据
     MSLB,供应商特殊库存(o)
     MKOL,供应商的特殊库存(k)
     MSKA,销售订单库存
     MCH1/MCHB,批次库存
     • WM库存数据:
     LQUA,份(quants错误翻译为数量)
     • 物料移动数据
     关键表:
     MKPF,抬头:物料凭证
     MSEG,凭证段:物料
     不是所有的物料移动数据都需要从这物料移动表中进行读取。
     生产订单相关 AUFM,采购订单相关 EKBE,销售相关 VBFA。
     • 移动类型
     借贷标示:MSEG-SHKZG,S表示增加库存、H表示减少库存
     关键表:
     T156*,移动类型
     T030,移动类型科目自动记账
     • WM的数据
     关键表:
     LTBK,转储请求抬头
     LTBP,转储请求项目
     LTAK,WM转储单抬头
     LTAP,转储单项目
     • 客户主数据
     KNA1,   基础数据
     KNB1,公司代码
     KNVV,销售组织
     ADRC,地址
     • 销售价格
     根据条件类型(如PR01)查找存储顺序(如PR02),得到表(如A305等A*表)
     KONP,条件记录号关联
     • 销售合同(销售意向)
     凭证类别G(VBAK-VBTYP)
     VBAK
     VBAP
     • 销售订单
     VBAK:      销售凭证 : 抬头数据
     VBAP:      销售凭证 : 项目数据
     VBEP:      销售凭证  :  计划行数据
     VBKD:      销售凭证  : 业务数据
     VBPA:      销售凭证 : 合作伙伴
     • 交货单
     LIKP
     LIPS
     • 发票凭证
     VBRK
     VBRP
     • 销售凭证流、凭证状态
     VBFA
     VBUK
     VBUP
     • 会计
     • 会计科目主数据
     SKA1,科目表
     SKB1,公司代码
     SKAT,科目描述
     • 成本要素
     CSKB,成本要素
     • 记账期间
     T001B
     财务供应商、财务客户(同后勤模块,维护事务代码FK01,只有公司代码数据)
     • 总账
     BKPF/BSEG
     FAGLFLEXT
     BSAS/BSIS
     GLFUNCT,功能范围
     • AR/AP
     BSAD/BSID
     BSAK/BSIK
     • AM
     ANLA
     • CO
     CSKS,成本中心
     COEP
     COSS(计划/实际,通过WRTTP区分,期间通过字段区分,如WTG004)
     COSP
     • CO-ML
     CKMLHD
     CKMLCR
     CKMLPR
     COPA
     CE*,如CE18000,8000指使用的经营范围
    CO与FI的区别及数据
    SAP增强技术
    用户出口(USER EXIT)
    增强(ENHANCEMENT)
    •  SMOD
    •  CMOD
    BADI
    •  SE18
    •  SE19
     Enhancement Spot
    •  ECC6.0后
     标准程序的修改(以CO02为例)
    •  SE95查看

  • 相关阅读:
    SpringBoot系统列 4
    SpringBoot系统列 3
    SpringBoot系统列 2
    SpringBoot系统列 1
    Nginx+Keepalived+Tomcat高可用负载均衡,Zookeeper集群配置,Mysql(MariaDB)搭建,Redis安装,FTP配置
    Java分布式集群,使用synchronized和Redis保证Job的原子性
    Linux 公网IP和内网IP,Dubbo提供者注册到了内网IP上怎么处理!
    SpringMvc自动任务调度之task实现项目源码,@Scheduled
    SFTP工具类
    Java代码实现文件添加数字签名、验证数字签名
  • 原文地址:https://www.cnblogs.com/hulianfei/p/6994730.html
Copyright © 2020-2023  润新知