SAP工具箱 多表导入程序

点击蓝字 关注我们

前言

前文介绍了一个通用导入程序及怎么配置通用导入程序的导入模板

通用导入程序

无峰,公众号:ABAP 技巧与实战SAP工具箱 通用导入程序

公众号交流群有人回复通用导入程序只能导入单表,用处不大.因为大部分单据,主数据的都是多表结构.

这里说明一下:

大部分配置表都是单表结构(文本表可以单独导入),可以直接导入数据.

之前介绍的通用导入程序只能导入到一个表中. 如果目标数据不是单表结构, 则需要创建一个临时存储表,先把数据导入到临时存储表中, 再调用处理程序写入正式表.这个更符合多表处理的实际情况.

本文主要介绍通用导入程序的升级版: ZUPLOAD_TABLE_CONTENT_MUL.可以同时处理多表的导入

场景描述

本文的示例场景中有三个表

ZTBCD_H                       补差单-抬头

ZTBCD_I                         补差单-明细(补差规则)

ZTBCD_I2                       补差单-补差结果明细

需要通过程序同时把数据导入到这三个表中.

这个场景需要忽略掉三个表的相关性数据校验. 因为这个相关校验逻辑个性化太强,很难通过配置实现.

配置过程

多个相关表同时导入需要先配置,才能执行

01

创建事务代码

  • 创建事务代码ZUP_BCD_MUL 调用多表导入程序:ZUPLOAD_TABLE_CONTENT_MUL

  • 创建事务代码ZUP_BCD_H 调用单表导入程序: ZUPLOAD_TABLE_CONTENT

  • 创建事务代码ZUP_BCD_I  调用单表导入程序: ZUPLOAD_TABLE_CONTENT

02

配置多表关系

在配置表ZTBC001D - EXCEL导入导出模板支持多表单(最多允许20个) 中配置事务代码和多表的关系.

每个TCODE 最多只能配置20个相关表.

多表关系可以直接配置表名,也可以配置TCODE ,通过配置ZTBC001获取表名.

下图的配置中:

  • ZUP_BCD_H  通过TCODE关联ZTBC001中的表

  • ZUP_BCD_I   通过TCODE关联ZTBC001中的表

  • ZTBCD_I2  直接使用表.

顺序字段内容控制了表在EXCEL中的标签顺序及导入后的屏幕界面呈现时的标签顺序

03

配置ZTBC001

在ZTBC001中维护TCODE 及相关的检查函数,出错保存等信息.

ZUP_BCD_MUL 表示总体处理的TCODE

ZUP_BCD_H  表示抬头表处理的TCODE

ZUP_BCD_I    表示行项目表出差的TCODE

因为ZTBCD_I2在ZTBC001D中直接配置的表名. 所以无需在ZTBC001中配置

04

配置每个表的模板

在配置表ZTBC001A为每个单独的表配置模板, 如果没有配置,则使用该表的全部字段.

具体配置方式详见链接

无峰,公众号:ABAP 技巧与实战SAP工具箱 配置导入模板

需要注意的是:

如果ZTBC001D中配置的是表名,则单表的模板, 字段ZTBC001A-TABNAME 中只能填写表名.

如果ZTBC001D中配置的是TCODE, 单表模板配置里可以填写事务代码或表名.

如下图,只为两个表配置了模板字段,个别字段加了非空检查,关键字段设置了重复性检查

执行多表导入

执行的过程与单表导入的过程差不多. 界面样式稍有差异.

01

调用TCODE

调用之前创建的TCODE  ZUP_BCD_MUL 表名位置会填ZTBC001- FILENAME(模板文件名).

02

产生模板

勾选产生模板,然后执行产生EXCEL模板,产生的模板中包含了三个表的字段模板(其中,前两个是根据配置表获取, 第三个表没有配置,获取所有表中字段)

03

导入数据

在模板中输入需要导入的数据,保存后, 在程序选择屏幕去掉产生模板复选框.执行导入数据

04

显示导入的数据

导入的数据会呈现在屏幕上,通过标签页区分不同的表

根据选择屏幕上的复选框 'X' 错误数据和正确数据一起显示 '' 错误数据单独显示

控制报错数据的显示方式

  • 图一 报错数据单独显示 

  • 图二 报错数据和正常数据一起显示

图一

图二

05

保存数据

点击保存后 ,数据会分别写入相应的表ZTBCD_H/ZTBCD_I/ZTBCD_I2

总结

程序ZUPLOAD_TABLE_CONTENT_MUL 是在程序ZUPLOAD_TABLE_CONTENT的基础上,增加了同时处理多表的功能. 两个程序同时支持模板配置中的所有显示规则,检查规则. 具体的配置逻辑可以理解为先为每个单表完成配置

详见链接

无峰,公众号:ABAP 技巧与实战SAP工具箱 配置导入模板

然后在多个单表配置的基础上, 再通过ZTBC001D配置表把所有单表配置的TCODE整合到一个多表TCODE中.

需要注意的是:

单表TCODE,调用ZUPLOAD_TABLE_CONTENT

多表TCODE,调用

ZUPLOAD_TABLE_CONTENT_MUL

目前尚未在项目中实际使用过这个多表导入.

究其原因是实际很少有多表同时导入的场景.因为表间关系比较复杂,往往需要先把多表数据导入一个临时表(主从表),再通过程序处理写入多表.

THE

END

约定

如果你对这篇文章感兴趣,请帮忙点赞,在看,分享.       

    (如果你真的喜欢这篇文章,请记得回来打个赏,作为支持我继续下去的动力,这是一个正反馈过程. 越多的人打赏,作者越有动力分享,读者就能享受更多的福利.毕竟打赏的金额富不了我,穷不了你,却能支持这个公众号长久发文.)

公众号 : syjf1976_abap

          ABAP开发技巧

微信号 : 392077

请微信联系管理员: 

syjf1976 

sharry_xlp  

Yannick_Duan 申请进入公众号讨论群

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值