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

ABAP SQL更新DB小技巧 WITH INDICATORS

在使用HTTP服务时我们更新数据时经常会使用到PUT或者PATCH,PUT的更新是完全以传入的字段信息为准,没有记录时进行创建,存在记录时完全依据传入的数据进行覆盖更新,而PATCH则是可以仅更新指定字段,而不影响其他字段,那在ABAP SQL中其实也有同样的功能,只是大多数时候都是为了方便直接使用了MODIFY语法进行更新(等同于PUT),这就要求如果是要更新记录时,你需要先获取目标数据的完整字段值信息,将你想更改的字段的值修改后,再次更新,那在ABAP Release 758之后,是可以使用WITH INDICATORS来达到PATCH更新的效果的,下面用一个简单的例子来说明下这个小技巧。


创建一张测试表:

TYPES定义更新结构:

TYPES:ty_dn_ind TYPE ztest_upd_ind WITH INDICATORS ind,tt_dn_ind TYPE SORTED TABLE OF ty_dn_ind WITH UNIQUE KEY id.

此处使用WITH INDICATORS关键字定义了一个更新结构,为了方便起见,直接debug看一下定义出来的结构就一眼明白这样定义的效果:

ind用来指定定义的结构名称,而这个结构的字段和定义的字段完全一致,只是默认类型是X类型,该结构的用处是在更新数据库表格时,起到一个控制的作用,只有当ind结构中对应的字段设置为01时,才会更新此字段,否则不进行任何更新,这个作用类似于BAPI中的X结构,熟悉RAP开发的顾问应该也已经联想到了,等同于EML语法更新BO时的%control结构。

实际使用例子:

*&---------------------------------------------------------------------*
REPORT ztest_update_db_with_ind.TYPES:ty_db_ind TYPE ztest_upd_ind WITH INDICATORS ind,tt_db_ind TYPE SORTED TABLE OF ty_db_ind WITH UNIQUE KEY id.DATA:lt_ins TYPE tt_db_ind,ls_ind TYPE ty_db_ind,lt_upd TYPE tt_db_ind,is_ind TYPE ty_db_ind.DELETE FROM ztest_upd_ind.lt_ins = VALUE #( ( id = '1' field1 = 'test1' field2 = 'test2' field3 = 'test3' ) ).INSERT ztest_upd_ind FROM TABLE @lt_ins.COMMIT WORK AND WAIT.
BREAK-POINT.lt_upd = VALUE #( ( id = '1' field1 = 'test1->change' ind-field1 = '01' ) ).UPDATE ztest_upd_ind FROM TABLE @lt_upd INDICATORS SET STRUCTURE ind.COMMIT WORK AND WAIT.
BREAK-POINT.

以上代码第一步,先清空测试表,然后插入一条测试数据:

然后构建更新内表,在设置主键之后,我们仅更新FIELD1字段,并且为FIELD1的控制字段设置为01,可以看到在更新之后,底表中仅FIELD1字段进行了变更,其他字段不受影响。

 当然这个控制结构的类型可以使用关键字TYPE自行执行,比如WITH INDICATORS ind TYPE abap_boolean,这样一来控制结构的类型就不再是00或者01来控制,而是abap_trueabap_false来控制,但是建议还是使用默认的类型,这样一来在RAP有些场景需要动态处理时,可以快速的进行mapping。

以上。

http://www.xdnf.cn/news/16872.html

相关文章:

  • W3D引擎游戏开发----从入门到精通【10】
  • 第二节 YOLOv5参数
  • 在 macOS 上通过 Docker 部署DM8 (ARM 架构)
  • 团队独立思考的力量
  • 2025-0803学习记录21——地表分类产品的精度验证
  • MySQL存储过程和触发器
  • 【网络安全】日志文件格式
  • 「源力觉醒 创作者计划」_文心大模型4.5系列开源模型, 从一行代码到一个生态:聊聊开源战略那些事儿,顺便扯扯文心大模型 4.5 的使用心得
  • 题解:P4447 [AHOI2018初中组] 分组
  • ospf综合
  • NX947NX955美光固态闪存NX962NX966
  • C++ STL 组件及其关系:从模块化设计到图形化展示
  • [硬件电路-124]:模拟电路 - 信号处理电路 - 测量系统的前端电路详解
  • HTTP数据请求
  • 【密码学】5. 公钥密码
  • 【Linux】多路转接之epoll
  • pytorch简单理解
  • 幂等性介绍和下单接口幂等性保证实现方案
  • python创建一个excel文件
  • realIADD3复现笔记
  • 【BTC】挖矿难度调整
  • AbstractExecutorService:Java并发核心模板解析
  • 入门MicroPython+ESP32:《点亮LED灯》
  • php完整处理word中表单数据的方法
  • K8S部署ELK(一):部署Filebeat日志收集器
  • Vue3+ts自定义指令
  • Linux 动静态库的制作和使用
  • 笔记:C语言中指向指针的指针作用
  • DyWA:用于可推广的非抓握操作的动态自适应世界动作模型
  • 【高等数学】第七章 微分方程——第七节 常系数齐次线性微分方程