【转载】SAP AMDP数据库存储过程,AMDP语法实例

e9f5aab2556eeb7902fb3d898ed04155.jpeg

好像灵隐寺那边拍的~

版权声明:本文为CSDN博主「Gong JX」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/qq_40977705/article/details/115932873

0d4f9941f841394b4f38abf05eb0d425.png

目录

AMDP介绍

AMDP语法

DECLARE变量声明

CURSOR循环(FOR)

数组的使用

IF...ELSE

内表读取

方法嵌套调用

AMDP function,AMDP函数实现

AMDP procedure,AMDP过程实现

常用函数

实例测试

AMDP介绍

AMDP(ABAP-Managed Database Procedure)是在ABAP层进行HANA数据库过程的实现和生命周期的管理,使用ABAP开发语言在ADT工具编HANA SQLScript。允许ABAP开发人员在HANA数据库层直接编写应用逻辑,即所谓的数据库存储过程。

AMDP类只能在ADT里进行开发,在SAP GUI里可以用只读的方式浏览源代码,无法编写

AMDP语法

AMDP是实现了一个特殊的类,并为这个类实现接口if_amdp_marker_hdb,这个接口就是这个类的特殊之处,该接口的实现表明了该类是一个AMDP类,可以编写AMDP代码。所以这类型接口也叫标记接口。

4b863c2737c9f4f36623c74c87ba168d.png

AMDP类的方法与普通的ABAP类方法相比也是有一些特殊之处的,它需要有一些关键字去修饰。BY DATABASE FUNCTION FOR HDB LANGUAGE SQLSCRIPT表明被修饰的方法是一个AMDP的容器,实现语言为HANA SQLScript,实现体内以只读方式访问数据库表SPFLI。

a80bf0f119de45c90f3cf7c5fd59cf48.png

DECLARE变量声明

AMDP中变量,内表的定义使用关键字DECLARE

DECLARE LV_txt "$ABAP.type( CHAR20 )" ; "字符串变量
DECLARE lv_index int ; "数字整形变量
DECLARE lv_datafr DATE; "日期类型
DECLARE lv_timefr TIME; "时间类型
"内表结构
DECLARE lt_RETURN TABLE (
     MANDT      "$ABAP.TYPE( MANDT )",
     FIELD1     "$ABAP.TYPE( CHAR20 )" ,
     FIELD2     "$ABAP.TYPE( CHAR20 )" ,
     FIELD3     "$ABAP.TYPE( CHAR20 )",
     FIELD4     "$ABAP.TYPE( CHAR20 )",
     FIELD5     "$ABAP.TYPE( INT1 )",
     FIELD6     "$ABAP.TYPE( CHAR20 )"  
   );

变量赋值使用 ‘:=’ 

LV_txt := 'test' ;

CURSOR循环(FOR)

游标CURSOR,使用游标可以先把数据取出来放到一张内表里,然后对它进行循环处理

DECLARE CURSOR lt_spfli FOR (
      select * FROM SPFLI  
   );
   for ls_spfli as lt_spfli do
     "...
   END FOR ;

数组的使用

   数组的使用方法类似C语言中的数组,可以使用索引的方式去读写

DECLARE ARRAY_TIME INTEGER ARRAY; /*定义int类型数组*/
 
    IV_TIMEFR := CURRENT_TIME ; /*当前系统时间*/
 
    ARRAY_TIME[1] := HOUR( :IV_TIMEFR);
    ARRAY_TIME[2] := MINUTE (:IV_TIMEFR);
    ARRAY_TIME[3] := SECOND (:IV_TIMEFR);

另外内表也可以用这种角标的方法去给某一行赋值,下面是一个完整的过程,只做演示。先从SPFLI表中获取数据,然后用游标去循环处理,将这些数据处理后(自行脑补)放入lt_return表结果集中返回。

METHOD GET_FLYDATAS BY DATABASE FUNCTION FOR HDB LANGUAGE SQLSCRIPT
                      OPTIONS READ-ONLY
                      USING SPFLI.
   DECLARE ARRAY_TIME INTEGER ARRAY;
   DECLARE lv_index   int ;
   DECLARE lt_return  TABLE (
 
                MANDT    "$ABAP.TYPE( MANDT )",
                Carrid   "$ABAP.TYPE( s_carr_id )",
                Connid   "$ABAP.TYPE( s_conn_id )"
                                     );
   DECLARE CURSOR lt_spfli FOR (
      select * FROM SPFLI
   );
   lv_index := 1;
   for ls_spfli as lt_spfli do
      lt_return.mandt[:lv_index] :=  :ls_spfli.mandt ;
      lt_return.mandt[:lv_index] :=  :ls_spfli.mandt ;
      lt_return.mandt[:lv_index] :=  :ls_spfli.mandt ;
      lv_index := :lv_index + 1;
   END FOR ;
   RETURN
     SELECT mandt, CARRID, CONNID FROM :lt_return;
 
 
  ENDMETHOD .

IF...ELSE

 条件判断和ABAP语法没太大区别,大致格式如下

if lv_index = 1 then 
      
      elseif lv_index = 2 then
      
      else 
      
      end if ;

内表读取

AMDP支持所有HANA SQL语句

LT_SPFLI = SELECT * FROM SPFLI ; 
   lv_index := 1;
   lv_len = record_count( :LT_SPFLI ) ;
   WHILE lv_index <= lv_len do 
     lv_field1 := :LT_SPFLI.carrid[ :lv_index ];
     lv_index  := :lv_index + 1 ;
   end WHILE ;

方法嵌套调用

AMDP方法有两种,一种是AMDP procedure,AMDP过程实现;另一种是AMDP function,AMDP函数实现。

BY DATABASE FUNCTION: 会将方法标记为table function

BY DATABASE PROCEDURE标记为存储过程.

FOR HDB: 设定数据库类型为HDB (HANA数据库).

LANGUAGE SQLSCRIPT: HANA数据库存储的语言.

OPTIONS READ-ONLY: 存储过程内不允许修改数据.

USING: 定义table function中消费的数据库表、视图或者存储过程等。

AMDP function,AMDP函数实现

AMDP function方法,关键字BY DATABASE FUNCTION FOR HDB LANGUAGE SQLSCRIPT添加了AMDP函数实现,这种AMDP方法,只能实现对CDS表功能的AMDP方法,CDS表函数的AMDP函数实现只能在静态AMDP类的公共可见性部分中声明,声明必须使用特殊形式的CLASS-METHODS语句 以及 FOR TABLE FUNCTION语句

7b6e0f758dfd8d4d7d93f8491df492c9.png

AMDP procedure,AMDP过程实现

AMDP过程实现用‘BY DATABASE PROCEDURE FOR HDB LANGUAGE SQLSCRIPT’修饰为过程实现,AMDP过程实现的方法不能为空。必须使用附加的USING声明在AMDP方法中访问,方法名必须大写。

DEFINITION

ef1ad1b4648a473e8578e6d30c32760e.png

IMPLEMENTATION

ae9000029abb32efff9227d65a552b38.png

USING

b506f556a9fc32a6d5531ef3543070d6.png

方法名大写

d9c99bb020763a74e3fcb6a1fd8c1c7a.png

常用函数

record_count(  ) 计算内表行

MOD(:lv_line , 2 )  取余

CURRENT_DATE 当前系统日期

CURRENT_TIME  当前系统时间

DAYS_BETWEEN()两个日期的间隔,返回INT值

HOUR()取小时

MINUTE()取分钟

SECOND ()取秒

实例测试

TABLE FUNCTION

@EndUserText.label: 'TEST TABLE FUNCTION'
define table function ZTEST_TABLEF
returns {
 key mandt : abap.clnt;
 key CARRID : s_carr_id ;
 key CONNID : s_conn_id ;
    
}
implemented by method ZCL_TEST_AMDP=>get_flydatas;

CODE

CLASS ZCL_TEST_AMDP DEFINITION
  PUBLIC
  FINAL
  CREATE PUBLIC .
 
  PUBLIC SECTION.
    INTERFACES if_amdp_marker_hdb.
    CLASS-METHODS:
       get_flydatas FOR TABLE FUNCTION ZTEST_TABLEF.
PROTECTED SECTION.
PRIVATE SECTION.
   CLASS-METHODS:
       get_data_FLY IMPORTING VALUE(iv_carrid) type s_carr_id
                              VALUE(iv_connid) TYPE s_conn_id
                    exporting value(iv_test) type i .
ENDCLASS.
 
CLASS ZCL_TEST_AMDP IMPLEMENTATION.
  METHOD GET_FLYDATAS BY DATABASE FUNCTION FOR HDB LANGUAGE SQLSCRIPT
                      OPTIONS READ-ONLY
                      USING SPFLI ZCL_TEST_AMDP=>get_data_FLY .
   DECLARE ARRAY_TIME INTEGER ARRAY;
   DECLARE lv_index   int ;
   DECLARE lv_test    int ;
   DECLARE lv_len     int ;
   DECLARE lv_field1   "$ABAP.TYPE( s_carr_id )";
   DECLARE lt_return  TABLE (
 
                MANDT    "$ABAP.TYPE( MANDT )",
                Carrid   "$ABAP.TYPE( s_carr_id )",
                Connid   "$ABAP.TYPE( s_conn_id )"
                                     );
   DECLARE CURSOR lt_spfli FOR (
      select * FROM SPFLI
   );
   lv_index := 1;
   for ls_spfli as lt_spfli do
      if lv_index = 1 then
         call "ZCL_TEST_AMDP=>GET_DATA_FLY"(
                                              iv_carrid => 'AA',
                                              iv_connid => '12',
                                              iv_test  => :lv_test
                                               );
      elseif lv_index = 2 then
 
      else
 
      end if ;
      lt_return.mandt [:lv_index]  :=  :ls_spfli.mandt ;
      lt_return.carrid[:lv_index] :=  :ls_spfli.carrid ;
      lt_return.connid[:lv_index] :=  :ls_spfli.connid ;
      lv_index := :lv_index + 1;
   END FOR ;
   RETURN
     SELECT mandt, CARRID, CONNID FROM :lt_return;
 
 
  ENDMETHOD .
 
 
  METHOD GET_DATA_FLY BY DATABASE PROCEDURE FOR HDB LANGUAGE SQLSCRIPT
                      OPTIONS READ-ONLY.
 
    iv_test = 1 ;
  ENDMETHOD.
 
ENDCLASS.

————————————————

版权声明:本文为CSDN博主「Gong JX」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/qq_40977705/article/details/115932873

推荐阅读:

ABAP新语法1

《ABAP新语法2》

《SM30添加按钮:批导,筛选,排序等完整demo 》

《关于 SM30/VIEW_MAINTENANCE_CALL锁整张表问题》

《Demo:弹出文本输入框》

《关于update task几个有意思的测试》

动态批量修改任意表任意字段的值

动态获取查询条件的一个小Demo

使用cl_gui_docking_container 实现多ALV》

VOFM 修改 组单开票时 会计凭拆分规则

DEMO SUBMIT 某程序并获取该程序ALV数据

DEMO:S/4 1809 FAGLL03H 增加字段增强

几个ABAP实用模板,体力活就别一行行敲了,复制粘贴得了

DEMO:BTE增强实现凭证创建检查

SAP Parallel Accounting(平行分类账业务)配置+操作手册+BAPI demo程序

CC02修改确认日期BAPI:Processing of change number  was canceled》《我是怎样调试BAPI的,以F-02为例

我是不是被代码给耽误了……不幸沦为一名程序员……

三亚自由行攻略(自己穷游总结)

苏州游记

记码农十周年(20110214--20210214)

不一样的SAP干货铺群:帅哥靓妹、红包、烤羊腿!

十年老码农搬砖习惯和技巧

我这个老码农是怎么debug标准程序的

我是怎样调试BAPI的,以F-02为例

杂谈:几种接口

Odata 增删改查详例

ODATA CREATE_DEEP_ENTITY 详例

RESTful DEMO 一:SAP 如何提供 RESTful Web 服务

RESTful DEMO 四 :增删改查及调用

DEMO  search help 增强 ( vl03n KO03 等)

录BDC时  弹出的公司代码框问题

《搜索帮助系列》

《增强相关》

Debug 系列

DEBUG  系列一:Dump debug
DEBUG  系列二:Configure Debugger Layer
DEBUG系列三:使用  F9 和 watch point
DEBUG系列四:第三方接口debug
DEBUG系列五:Update  模式下的function debug
DEBUG系列六:后台JOB  debug
DEBUG系列七:保存测试参数
DEBUG系列八:Debug弹出框
debug系列九:SM13查看update更新报错
DEBUG系列十:Smartforms  debug
DEBUG系列十一:GGB1  debug
Debug系列十二:QRFC  队列 debug
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值