在做系统集成时,你一定遇到过这种现实场景:主数据在 SAP 里被业务同事改了,外围系统也必须尽快同步,但又不可能让接口在每一次保存时都立刻全量发送。结果就是两种声音互相拉扯——业务希望实时,技术希望可控、可追溯、可批处理。
ALE Change Pointers 的价值,恰恰在这条缝隙里:它把发生了哪些变化这件事记录下来,把何时发送、发给谁、以什么粒度发送交给后续的分发逻辑去决定,从而把业务写入与系统分发解耦。
Change Documents 与 Change Pointers:同源但目标不同
Change Documents 记录的是谁在什么时候改了什么
很多 SAP 应用在更新数据库时,会写入 Change Documents。最典型的落库表就是CDHDR(抬头)与CDPOS(行项目):
CDHDR更像一次变更的事件头,包含对象、用户、时间等信息CDPOS保存字段级的变化明细,包括表名、字段名、旧值、新值等
这套机制的一个关键点在于:字段是否会被记录,往往受数据元素在字典里是否标记为 Change Document 相关影响,也就是你在SE11的 Data Element 里