SAP 工具箱 数据同步平台(八 改进数据过滤机制)

点击蓝字 关注我们

前言

数据同步平台是在ABAP中开发的一个数据同步工具,类似于LTRC,通过配置实现任意两个数据库的数据同步(ABAP需要配置相关的外部数据库连接).

数据同步平台的底层通过调用ADBC类实现远程数据库的读取,写入.

本文主要介绍数据同步平台的数据过滤机制

数据过滤

数据同步平台可以通过如下三种方式实现从源数据库读取数据的过滤

  • 方式一: 源系统创建的视图中使用条件过滤

  • 方式二: 配置读取源数据的过滤条件

  • 方式三: 选择屏幕针对特定接口动态设置过滤条件

方式一

源系统创建视图中使用条件过滤

详见链接

无峰,公众号:ABAP 技巧与实战SAP工具箱 数据同步平台( 七 创建一个接口)

数据同步平台支持从源系统的视图中获取数据,开发可以在视图中通过where 语句给获取的数据添加过滤条件

2621207ab21ce3f2b605a6937b72d623.png

方式二

配置读取源数据的过滤条件

配置详见链接

无峰,公众号:ABAP 技巧与实战SAP工具箱 数据同步平台( 二 配置 )

改进部分详见链接

无峰,公众号:ABAP 技巧与实战SAP工具箱 数据同步平台(三 改进)

配置中可以针对主表设置过滤条件, 主表过滤条件会带入从表数据的获取逻辑.

也可以对从表设置单独的过滤条件.(比如,如果传输订单, 通过设置删除标记为空, 过滤掉存在删除表的明细数据)

01150bc4034d22ff49ec41a79196830e.png

方式三

选择屏幕针对单一接口动态设置过滤条件

考虑到实际同步数据时, 用户可能手工指定特定条件的数据同步, 因此对数据同步平台做了如下改进

在接口模式下添加了动态设置主表过滤条件的功能

5be8f80cb74b98d6887bdc8fd768a4ca.png

当仅限定一个接口编号时, 可以点击过滤条件按钮进入动态选择条件设定屏幕

在动态选择条件屏幕展开特定的表,双击字段后,可以为字段输入选择条件.

0572382fd775fbfd5314d0af981d8987.png

点击执行按钮,条件被保存

87c5f72c430b9cbdb949653648709d9d.png

最终执行的结果中 , 可以看到补充的过滤条件

0f1a376ec62dd131bd1abc8a44b2ad77.png

选择屏幕中可以通过输入特定接口后回车方式获取预存的过滤条件

临时 复选框 用于确定该过滤条件仅对当前用户生效,如果去除临时复选框创建的过滤条件将对正式执行接口生效.

991af62df095f37d45e5e36ae1c988ec.png

三种方式比较

上述三个方式均可以给通过数据同步平台同步的接口添加过滤条件.

  • 方式一和方式二 适用于开发人员配置接口时,实现按业务指定接口逻辑实现数据过滤

  • 方式三的临时模式适用于用户在实际接口传输时手工指定要传输的数据(同时受限于方式一与方式二中的数据过滤).

  • 方式三中的非临时模式会参与接口后台执行时的过滤条件. 作为方式一,方式二业务逻辑的补充,需要谨慎使用.

方式三的动态设置过滤条件暂时不支持表模式, 后续考虑补充该功能.

12b33030118ad223938e66652b152067.png

动态过滤补充说明

对于动态选择字段不显示的补充处理

在CDS视图中通过函数,计算,常量等方式定义的字段, 通过参数给字段添加的名称在ABAP中无效

@EndUserText.label: '字段描述'

可以通过CAST语句把字段定义为一个数据字典中存在的数据元素,解决这个标签问题(这种方式支持多语言,同时会附加数据元素的其它特性,比如前置0转换,有时会带来负面的影响,同时这样会增加CDS视图的复杂度)

abbf89fe1f5155a72c6c43e1c4e73a1a.png

4952daa0609e0c5334fd68cf1dbf4563.png

也可以使用下面的方法

增强了配置表ZTBC_ALV ,可以为这些字段补充字段描述(该表未考虑多语言,只能输入一种语言的描述,可以考虑改进). 

f193f77428e672242f4f408b3e22adb9.png

总结

数据同步平台是对项目低代码的一种尝试,尽量通过配置或者CDS视图开发完成项目中接口类程序的开发(目前只支持写入中间库的接口).

动态报表则是对项目中报表类程序开发的低代码化的应用.

详见链接

无峰,公众号:ABAP 技巧与实战动态报表D-Query简介

通过在项目的正式应用,会逐渐补充更多的功能.

目前想到的后续可能的改进点:

目标数据库扩展为FTP服务器,HTTP调用或PO调用 . 通过配置把源系统的数据(通过CDS视图实现数据的获取逻辑)转换成CSV文件,XML文件或JSON文件,或PO调用的嵌套内表. 写入目标FTP服务器或者调用目标http服务地址传递XML或JSON文件,或调用PO生成的类.

想想还有点激动: 如果这个改进功能实现了. 数据同步平台基本上就能完成一多半的接口开发(数据从S4系统发出,外围系统接收或者数据从中间库同步到S4系统的自定义表).

通过PO的下传接口程序生成

详见链接

无峰,公众号:ABAP 技巧与实战SAP工具箱 自动生成发出接口程序(一)

约定

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

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

925e6301523b0e680d39df19b6f6200b.png

公众号 : syjf1976_abap

          ABAP开发技巧

微信号 : 392077

请微信联系管理员: 

syjf1976 

sharry_xlp  

Yannick_Duan 

申请进入公众号讨论群提问或者参与话题讨论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值