ABAP 之如何传输数据时分批传输

举报
百里丶落云 发表于 2023/08/30 10:36:48 2023/08/30
【摘要】 序HELLO,这里是百里,一个学习中的ABAPER,在工作中,你们是否有遇到,数据量非常大的时候,是那种非常非常大的数据,比如接口,比如上传,比如下发订单信息这种,都是非常大的数据量. 那么该如何解决呢.此时会用到今天的技术,传输数据时分批传输. 为什么要分批传输数据百里曾经遇到过,非常大的数据,下发要2个小时那种. 介于接口接收端的承受能力,此时如果不使用分批次下发数据.就可能会出现TI...

HELLO,这里是百里,一个学习中的ABAPER,在工作中,你们是否有遇到,数据量非常大的时候,是那种非常非常大的数据,比如接口,比如上传,比如下发订单信息这种,都是非常大的数据量. 那么该如何解决呢.此时会用到今天的技术,传输数据时分批传输.

为什么要分批传输数据

百里曾经遇到过,非常大的数据,下发要2个小时那种. 介于接口接收端的承受能力,此时如果不使用分批次下发数据.就可能会出现TIME OUT 的情况, 这时,我们的数据就白发了,还可能需要重新发的情况 .此时分批次下发的需求应运而生.我们讲数据分成多段,逐级下发,这样就可以有效避免数据的多次下发无效造成的问题.

技术讲解

本功能并不是使用什么函数,就是使用WHILE 循环, 将数据行数确定后,然后通过,通过输入指定参数,控制数据分堆,我们将数据分成多少堆,然后分批去执行某一个或者某些函数,从而减少因为数据量过大而造成卡机问题.

WHILE lv_end < lines( lt_data_temp ).
......

INSERT LINES OF lt_data_temp FROM lv_start TO lv_end INTO TABLE lt_data .

ENDWHILE .

实际案例

本次案例内容讲的是一个接口下发的案例,下发的代码我就不放在里面了,因为会特别特别的多.我这里只是讲我如何把数据量非常大的数据,给通过算法,分成一个一个的小堆从而执行函数的.

数据准备

TYPES : BEGIN OF ty_Data ,   
  name TYPE char20 ,   
  age TYPE char20,  
  address TYPE char20 ,  
    
  END OF ty_Data .   
  
data : gs_Data TYPE ty_Data .   
data : gt_data TYPE TABLE OF ty_Data .

获取数据

INITIALIZATION .
START-OF-SELECTION .   
  
select * from  zmessage into CORRESPONDING FIELDS OF table gt_Data .

设定子例程

*&---------------------------------------------------------------------*  
*& Form sed_mesg  
*&---------------------------------------------------------------------*  
*& text  
*&---------------------------------------------------------------------*  
*& -->  p1        text  
*& <--  p2        text  
*&---------------------------------------------------------------------*  
FORM sed_mesg .  
  data(gt1_Data) = gt_Data .
  DATA: gv_max TYPE i VALUE 250.  
  
  DATA : lt_data TYPE TABLE OF ty_Data.  
 data  :  lt_data_temp TYPE TABLE of ty_Data .  
"数据量分配传  
  DATA : lv_start TYPE  i  VALUE IS INITIAL,  
         lv_end   TYPE i VALUE IS INITIAL.  
  lt_data_temp[] = gt1_data[].  
    lv_start = 0.  
    lv_end = 0.  
WHILE lv_end < lines( lt_data_temp ).  
      CLEAR l_input1.  
      lv_start = lv_end + 1.  
      lv_end = lv_end + gv_max.  
      IF lv_end > lines( gt1_data ).  
        lv_end = lines( gt1_data ).  
      ENDIF.  
  
      CLEAR lt_data.  
      INSERT LINES OF lt_data_temp FROM lv_start TO lv_end INTO TABLE lt_data .
     REFRESH gt_Data .  
     gt_Data[] = lt_data[] .
"数据转换,及数据处理函数  
  
  "调用发送函数
  IF l_input1 IS INITIAL.  
    RETURN .  
  ENDIF.  
  
" 需要分批执行的函数  
  
ENDWHILE .  
ENDFORM.

调用子例程

PERFORM sed_mesg  .

结果及反思

如图所示,我们下发了多条数据,成功的避免了因为一条数据过而造成卡机或者响应失败的问题.
image.png

反思

不过使用这个也会出现一些问题,就是IO 操作过于频繁的问题.知道的SAP是单进程的东西,不能像其他语言一样可以多个线程进行或者协程等等,总是就是很慢.我们需要反复进行请求目的接口.造成了不必要资源浪费,如果不考虑数据会断的情况,把数据拆分一堆一堆的会比单独直接下发的慢.

技术总结.

今天讲述的内容是,将数据量非常的内容如何分批次,执行一些命令. 这样做的好处是,可以避免一些因硬件如网络,电脑等设备数据量太大产生的中断现象.学会了这个,当你做接口时,尤其是实时接口时,就可以完美解决问题.

百里鸡汤

做出承诺,并做出坚定且持续的行动.

这里是百里,一个努力的学习者. 努力学习好好记录,点滴进步,就是成功.

wallhaven-2kydym.jpg

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。