当前位置: 首页 > news >正文

MOVE_CORRESPONDING_ITAB

使用MOVE-CORRESPONDING时可以通过KEEPING TARGET LINES实现追加而不是覆盖。
SAP 的实例Demo

REPORT demo_move_corresponding_itab. CLASS demo DEFINITION. PUBLIC SECTION. CLASS-METHODS main. PRIVATE SECTION. TYPES: c3 TYPE c LENGTH 3, BEGIN OF iline1, col1 TYPE c3, col2 TYPE c3, END OF iline1, BEGIN OF iline2, col2 TYPE c3, col3 TYPE c3, END OF iline2, BEGIN OF line1, col1 TYPE c3, col2 TYPE c3, col3 TYPE STANDARD TABLE OF iline1 WITH EMPTY KEY, END OF line1, BEGIN OF line2, col2 TYPE c3, col3 TYPE STANDARD TABLE OF iline2 WITH EMPTY KEY, col4 TYPE c3, END OF line2. CLASS-DATA: itab1 TYPE STANDARD TABLE OF line1 WITH EMPTY KEY, itab2 TYPE STANDARD TABLE OF line2 WITH EMPTY KEY, out TYPE REF TO if_demo_output. CLASS-METHODS: fill_tables, display_table1, display_table2. ENDCLASS. CLASS demo IMPLEMENTATION. METHOD main. DATA buffer LIKE itab2. out = cl_demo_output=>new( ). fill_tables( ). out->begin_section( `itab1` ). display_table1( ). out->next_section( `itab2` ). display_table2( ). buffer = itab2. out->begin_section( `MOVE-CORRESPONDING` ). MOVE-CORRESPONDING itab1 TO itab2. display_table2( ). itab2 = buffer. out->next_section( `MOVE-CORRESPONDING KEEPING TARGET LINES` ). MOVE-CORRESPONDING itab1 TO itab2 KEEPING TARGET LINES. display_table2( ). itab2 = buffer. out->next_section( `MOVE-CORRESPONDING EXPANDING NESTED TABLES` ). MOVE-CORRESPONDING itab1 TO itab2 EXPANDING NESTED TABLES. display_table2( ). itab2 = buffer. out->next_section( `MOVE-CORRESPONDING EXPANDING NESTED TABLES ` && `KEEPING TARGET LINES` ). MOVE-CORRESPONDING itab1 TO itab2 EXPANDING NESTED TABLES KEEPING TARGET LINES. display_table2( ). out->display( ). ENDMETHOD. METHOD fill_tables. itab1 = VALUE #( ( col1 = 'a11' col2 = 'a12' col3 = VALUE #( ( col1 = 'a11' col2 = 'a12' ) ( col1 = 'a21' col2 = 'a22' ) ) ) ( col1 = 'b21' col2 = 'b22' col3 = VALUE #( ( col1 = 'b11' col2 = 'b12' ) ( col1 = 'b21' col2 = 'b22' ) ) ) ( col1 = 'c31' col2 = 'c32' col3 = VALUE #( ( col1 = 'c11' col2 = 'c12' ) ( col1 = 'c21' col2 = 'c22' ) ) ) ). itab2 = VALUE #( ( col2 = 'x11' col3 = VALUE #( ( col2 = 'x11' col3 = 'x12' ) ( col2 = 'x21' col3 = 'x22' ) ( col2 = 'x31' col3 = 'x32' ) ) col4 = 'x12' ) ( col2 = 'y21' col3 = VALUE #( ( col2 = 'y11' col3 = 'y12' ) ( col2 = 'y21' col3 = 'y22' ) ( col2 = 'y31' col3 = 'y32' ) ) col4 = 'y22' ) ). ENDMETHOD. METHOD display_table1. DATA: BEGIN OF outl, col1 TYPE c3, col2 TYPE c3, col31 TYPE c3, col32 TYPE c3, END OF outl. DATA output LIKE STANDARD TABLE OF outl WITH EMPTY KEY. LOOP AT itab1 ASSIGNING FIELD-SYMBOL(<wa>). outl-col1 = <wa>-col1. outl-col2 = <wa>-col2. LOOP AT <wa>-col3 ASSIGNING FIELD-SYMBOL(<col3>). outl-col31 = <col3>-col1. outl-col32 = <col3>-col2. IF sy-tabix > 1. CLEAR outl-col1. CLEAR outl-col2. ENDIF. APPEND outl TO output. ENDLOOP. ENDLOOP. out->write( output ). ENDMETHOD. METHOD display_table2. DATA: BEGIN OF outl, col2 TYPE c3, col32 TYPE c3, col33 TYPE c3, col4 TYPE c3, END OF outl. DATA output LIKE STANDARD TABLE OF outl WITH EMPTY KEY. LOOP AT itab2 ASSIGNING FIELD-SYMBOL(<wa>). outl-col2 = <wa>-col2. outl-col4 = <wa>-col4. LOOP AT <wa>-col3 ASSIGNING FIELD-SYMBOL(<col3>). outl-col32 = <col3>-col2. outl-col33 = <col3>-col3. IF sy-tabix > 1. CLEAR outl-col2. CLEAR outl-col4. ENDIF. APPEND outl TO output. ENDLOOP. ENDLOOP. out->write( output ). ENDMETHOD. ENDCLASS. START-OF-SELECTION. demo=>main( ).

结果展示

itab1

OUTPUT
COL1COL2COL31COL32
a11a12a11a12
a21a22
b21b22b11b12
b21b22
c31c32c11c12
c21c22

itab2

OUTPUT
COL2COL32COL33COL4
x11x11x12x12
x21x22
x31x32
y21y11y12y22
y21y22
y31y32

MOVE-CORRESPONDING

OUTPUT
COL2COL32COL33COL4
a12a11a12
a21a22
b22b11b12
b21b22
c32c11c12
c21c22

MOVE-CORRESPONDING KEEPING TARGET LINES(追加)

OUTPUT
COL2COL32COL33COL4
x11x11x12x12
x21x22
x31x32
y21y11y12y22
y21y22
y31y32
a12a11a12
a21a22
b22b11b12
b21b22
c32c11c12
c21c22

MOVE-CORRESPONDING EXPANDING NESTED TABLES(匹配嵌入的对应字段)

OUTPUT
COL2COL32COL33COL4
a12a12
a22
b22b12
b22
c32c12
c22

MOVE-CORRESPONDING EXPANDING NESTED TABLES KEEPING TARGET LINES

OUTPUT
COL2COL32COL33COL4
x11x11x12x12
x21x22
x31x32
y21y11y12y22
y21y22
y31y32
a12a12
a22
b22b12
b22
c32c12
c22
http://www.rkmt.cn/news/174662.html

相关文章:

  • 2025安全门窗大型厂家品牌TOP5权威推荐:甄选优质品牌助力家居安全升级 - 工业品牌热点
  • PyTorch-CUDA镜像能否用于水资源管理决策
  • PyTorch-CUDA镜像能否用于体育动作识别分析
  • 2025年最新低烟无卤阻燃电缆优选TOP5:陕纵缆领衔,实力派厂家全解析 - 深度智识库
  • 计算机毕业设计springboot基于BS的旅店信息管理系统 SpringBoot 驱动的 Web 端旅店综合业务平台 基于浏览器/服务器架构的客栈智慧运营系统
  • 2025年热门的环保选煤设备厂家实力及用户口碑排行榜 - 品牌宣传支持者
  • 2025年金山附近优秀的家装工作室有哪些,法式软装设计/法式室内设计/新中式软装设计/新中式精装房设计,家装工作室有哪些 - 品牌推荐师
  • GPUStack Windows(WSL2)部署指南
  • 2025年长三角屏蔽袋优质服务厂家排名:镀铝屏蔽袋厂家TOP5推荐 - myqiye
  • Pinia 实战:志愿填报系统全局数据管理核心流程
  • 元旦节直播物料如何筹备?现成模板+必选道具,直接抄作业
  • 2025年热门的四向车立体库厂家最新TOP实力排行 - 品牌宣传支持者
  • html大文件上传插件的加密存储原理与思路
  • 2025年靠谱SAP系统服务商年度排行榜:外贸行业SAP系统品牌公司与维护推荐 - 工业设备
  • Spring IoC 与 DI 核心原理学习笔记(根据黑马课程ssm笔记总结)
  • 防脱洗发水排行榜口碑最好的十款!哪款洗发水防脱最靠谱?第一名无硅油中药配方更安心 - 博客万
  • PyTorch-CUDA-v2.7镜像在学术研究中的应用前景
  • Matlab模型下的“共享储能电站“在工业用户日前优化经济调度中的实践与场景3不完全复现
  • 超高分子量聚乙烯含硼板生产商哪家好?售后好的加工厂推荐 - 工业品牌热点
  • 2025年无线门禁系统品牌商排名:宿舍门禁系统品牌推荐 - 工业设备
  • PyTorch-CUDA镜像中运行Whisper模型的体验报告
  • PyTorch-CUDA镜像中如何监控GPU利用率
  • PyTorch-CUDA镜像如何降低大模型训练成本
  • Safeguard Global名义雇主EOR服务商-2026年企业出海德国合规雇佣的优选方案 - 品牌2025
  • 最有效的抗衰产品?内服抗衰老哪个牌子最好?抗衰老保健产品排行榜,科学认证十款热门口碑分析,超靠谱 - 博客万
  • 我发现流式写入性能差后来才知道用writev批量合并数据块
  • 2025 CISCN 初赛 部分题目wp
  • java+vue+SpringBoot社区医院管理系统(程序+数据库+报告+部署教程+答辩指导)
  • java+vue+SpringBoot二手车交易系统(程序+数据库+报告+部署教程+答辩指导)
  • 2026年中东市场拓展优选:Safeguard Global名义雇主EOR服务商推荐 - 品牌2025