SAP AMDP数据库存储过程,AMDP语法实例

目录

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代码。所以这类型接口也叫标记接口。

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

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语句

AMDP procedure,AMDP过程实现

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

DEFINITION

 IMPLEMENTATION

USING

方法名大写

常用函数

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.

  • 8
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: ABAP是一种用于SAP系统开发的编程语言,它是一种高级语言,用于在SAP环境中编写业务逻辑。ABAP语法是ABAP程序的书写规则,用于定义数据对象、变量、函数、方法等,以实现所需的功能。 ABAP的关键语法包括:数据类型定义、变量声明、语句结构、逻辑控制、循环结构、函数和方法定义等。通过这些语法,开发人员可以对数据进行处理、进行条件判断、循环操作以及定义自定义的功能模块。 ABAP语法中的数据类型定义包括:整数、浮点数、字符串、日期、时间等。开发人员可以根据需要选择合适的数据类型来定义变量,并进行数据操作。变量声明可以通过关键字"DATA"或"FIELD-SYMBOLS"进行,这些关键字可以指定变量的数据类型、长度、可见性等属性。 在ABAP语法中,还有一些重要的语句结构。例如,条件语句(IF...ELSE...ENDIF)用于根据条件选择不同的执行路径;循环语句(DO...END...WHILE)用于多次执行同一段代码;选择语句(CASE...WHEN...ENDCASE)用于根据不同的条件选择执行不同的代码块。 除此之外,ABAP语法还支持函数和方法的定义。函数是一段独立的代码块,可以接受输入参数并返回结果;方法则是与对象关联的代码块,用于对特定对象进行操作。 总之,ABAP语法是开发ABAP程序的基础,它提供了丰富的功能和灵活的语言结构,使得开发人员可以根据需要编写复杂的业务逻辑,并在SAP系统中实现各种功能。通过熟悉ABAP语法,开发人员可以高效地进行开发工作,并实现各种业务需求。 ### 回答2: ABAP(Advanced Business Application Programming)是一种用于SAP系统的编程语言,它最初是为SAP R/3系统开发的。随着SAP系统的升级和改进,ABAP也进行了相应的发展,现今最新版本是ABAP S/4HANA。 ABAP S/4HANA是在SAP S/4HANA平台上使用的ABAP版本,它与传统的ABAP有一些重要的区别。首先,ABAP S/4HANA采用了新的数据模型,即S/4HANA物料管理(Material Ledger)和简化数据模型(SIMM)等,这些模型使用了新的内部数据技术,提高了数据处理性能和效率。 其次,ABAP S/4HANA引入了新的ABAP编程范式,例如ABAP CDS(Core Data Services)。ABAP CDS提供了一种声明式的编程方式,用于定义和处理数据模型、服务和视图。这种新的编程范式可以更好地支持SAP S/4HANA中的新功能,并且使开发人员能够更轻松地创建和维护ABAP应用程序。 此外,ABAP S/4HANA还引入了更多的功能和特性,以优化开发和运行ABAP应用程序的性能。例如,它引入了ABAP Managed Database Procedures(AMDP),用于在数据库中执行复杂的计算和处理。它还提供了更好的集成工具,如ABAP Test Cockpit和ABAP Development Tools,用于支持开发和测试过程。 总结而言,ABAP S/4HANA是ABAP语言在SAP S/4HANA平台上的最新版本,它引入了新的数据模型、编程范式和功能,以更好地支持SAP S/4HANA系统,并提高开发和运行ABAP应用程序的性能。 ### 回答3: ABAP是一种高级业务应用程序编程语言,用于开发SAP软件解决方案。ABAP语法包括各种关键字、数据类型、操作符、语句和类等。 首先,在ABAP语法中,我们使用不同的关键字来声明变量、常量和数据类型。例如,使用“DATA”关键字来声明一个变量,使用“CONSTANTS”关键字来声明一个常量,并使用不同的数据类型(例如整数、字符、日期等)来定义变量或常量。这些关键字和数据类型使开发者能够方便地处理数据和进行计算。 其次,在ABAP语法中,我们可以使用各种操作符来进行数学、逻辑和比较操作。例如,加号“+”用于加法运算,减号“-”用于减法运算,等号“=”用于比较操作等。这些操作符帮助我们在编写程序时进行各种运算和判断。 然后,在ABAP语法中,我们使用各种语句来实现不同的功能。例如,我们可以使用“IF”语句来实现条件判断,根据条件的结果执行不同的操作。我们还可以使用“DO”语句来实现循环操作,重复执行一段代码。此外,还有其他语句,例如“CASE”语句、 “LOOP”语句等,用于不同的编程需求。 最后,在ABAP语法中,我们还可以创建和使用类来组织和管理代码。类是一种封装了数据和方法的数据结构,可以实现面向对象的编程。通过创建类和使用类的方法,我们可以更好地管理代码,并实现可重用的功能。 综上所述,ABAP是一种用于开发SAP软件解决方案的编程语言,它有着丰富的语法规则,包括关键字、数据类型、操作符、语句和类等。了解和掌握ABAP语法对于开发高效、可靠的SAP应用程序至关重要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Gong JX

多谢鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值