Function介绍与示例
ABAP管理下的数据库存储过程(ABAP-Managed Database Procedure,以下简称AMDP)是在APAP on SAP HANA开发中的一种优化模式。AMDP使用数据库语言书写,比如Native SQL或者是SQL Script,并且在AMDP类的AMDP方法内实现。因此用它开发数据库存储过程就有点类似于编辑ABAP类。
ABAP CDS Table Function
在ABAP CDS Table Function的开发过程中,我们将字段结构、参数(可选)、association等通过类/方法定义为实体。通过AMDP我们可以直接在ABAP层写存储过程,并且把它封装在类/方法中,更多介绍可以看之前的文章:Function介绍与示例。ABAP中的AMDP(ABAP-Managed Database Procedures 。
Function介绍与示例。因为AMDP直接运行数据库脚本,所以需要做几个额外的步骤并且会使用到脚本语言(在HANA中即SQL Script)。稍后在示例部分我们会讨论配置的细节。
Function介绍与示例。通过上文介绍的这两种开发技术,我们可以开始开发一个技术示例了。按本文的例子做下去,你将会可以创建你自己的ABAP CDS Table Function,并且为不能直接通过ABAP CDS实现的需求提供解决方案。为了实现示例,我们会使用数据库视图SFLIGHTS,这一视图提供了航班连接的细节。
为什么使用AMDP?
按SAP的官方建议,在可以使用Open SQL实现需要的功能或优化目标的时候,不建议使用AMDP。而在需要使用Open SQL不存在的特性,或者是大量处理流和分析导致了数据库和应用服务器之间有重复的大量数据传输的情况下,则应当使用AMDP。
具体的例子可以看看:AMDP, Comparison of SQLScript with Open SQL ,
SAP HANA, Currency Conversion with SQLScript
AMDP还能提供以下好处:
- SQL Script的静态代码检查
- 语法高亮(支持pretty printer格式优化器)
- 在AMDP内访问其它AMDP方法、ABAP字典的视图和表
- 可以像普通的ABAP方法一样调用(不包括AMDP function)
- 使用ST22进行运行时错误的详细分析
介绍视频:
ABAP CDS视图
在通常的ABAP CDS视图开发过程中,我们通过编辑器(通常是ADT)在ABAP层声明了我们的字段结构和annotations。激活后,系统会自动地在数据库层生成所有的SQL视图。
ABAP CDS视图提供多种SQL命令和函数的支持,如果你想要了解细节和全部的可用特性,建议你看这篇文章:ABAP CDS Feature Matrix。
总结
使用ABAP Managed Database Procedure(AMDP)和CDS开发,属于自上而下的ABAP for HANA开发方式。在应用层即ABAP程序中管理数据计算逻辑和建模,激活后会在HANA中创建相应的数据库对象。相比于旧有的Database Procedure Proxy,AMDP提供了简单的调用SQL Script等数据库语言的方式。
参考文章:
[Function介绍与示例。1] AMDP - ABAP Managed Database Procedures
[Function介绍与示例。2] ABAP Managed Database Procedures – Introduction
[3] ABAP Development for SAP HANA
[4] Function介绍与示例。How to use AMDP Function implementation for a CDS Table Function as a data source in CDS views
其他资料:
SAP HANA SQL Script Reference
ABAP CDS Table Function介绍与示例
如我们所知,HANA CDS只支持HANA数据库,ABAP CDS理论上支持多种数据库供应商,结果是,ABAP CDS相比之下要少一些功能。因此,在某些情况下,无法使用ABAP CDS解决问题时,可以使用一种变通的方法,即通过ABAP Managed Database Procedures (AMDP)创建ABAP CDS Table Function。
工具支持
AMDP在SAP NetWeaver AS ABAP 7.40 SP05版本中被引入。只有基于Eclipse的开发工具(即ADT,版本要不低于2.19)才支持AMDP的编辑,SAP GUI上面的SE80是不提供编辑功能的,只能用来阅读代码。
有关AMDP调试的视频教程:
注:本文的主要理论内容已经包含在之前的AMDP介绍文章:ABAP中的AMDP(ABAP-Managed Database Procedures ) 中,相比它,本文更像一个step by step教程。
AMDP procedure实现
需要使用Method语句的附加项BY DATABASE PROCEDURE。例子见上文。这种实现方式写成的方法和普通的ABAP对象方法在使用方式上没区别。
开发
打开你的HANA Studio(或者ADT),创建一个新的Core Data Services -> Data Definitio。
选择project,package并且定义名字和描述:
选择传输请求,然后点击Next。在模板中选择最后一个选项“Define Table Function with Parameters”,然后点击Finish:
编辑生成的实体,包含以下内容:
- 字段:
- Client
- Airline Code
- Airline Name
- Cities To
- 类: ZCL_FLIGHTS_DEMO_CDS
- 方法: FLIGHTS_CONNECTIONS
结果应该是:
define table function ZDEMO_FLIGHTS_TABLE_FUNCTION
returns
{
client : abap.clnt;
airline_code : s_carr_id;
airline_name : s_carrname;
cities_to : abap.string;
}
implemented by method
ZCL_FLIGHTS_DEMO_CDS=>FLIGHTS_CONNECTIONS;
当然,现在ZCL_FLIGHTS_DEMO_CDS还不存在。下一步,让我们创建它:
让类包含IF_AMDP_MARKER_HDB接口。这一步会把你的ABAP类转换为AMDP类,并且允许在类的方法内写存储过程。
PUBLIC SECTION.
INTERFACES if_amdp_marker_hdb.
在方法实现中我们需要引入某些配置选项:
- BY DATABASE FUNCTION: 会将方法标记为table function,还有一个选项是通过 BY DATABASE PROCEDURE标记为存储过程.
- FOR HDB: 设定数据库类型为HDB (HANA数据库).
- LANGUAGE SQLSCRIPT: HANA数据库存储的语言.
- OPTIONS READ-ONLY: 存储过程内不允许修改数据.
USING: 定义table function中消费的数据库表、视图或者存储过程。在本例中,只访问SFLIGHTS 视图.
METHOD flights_connections
BY DATABASE FUNCTION FOR HDB LANGUAGE SQLSCRIPT OPTIONS READ-ONLY USING sflights. <<你的代码>>
ENDMETHOD.
让我们准备好查询分割逻辑的两个SELECT语句。
第一个SLECT需要获取Client, Airline Code, Airline Name和City To字段,并通过DISTINCT关键字去重,因为我们会找到在不同的连接日期的相同的航空公司的城市记录,如图:
AMDP的优点之一是你可以将SELECT的查询结果传输至“内表”,并且可以执行新的SELECT来读取它的数据。让我们应用这一功能的优点,并且将第一个SELECT的语句的查询结果命名为itab_cities.
itab_cities =
SELECT DISTINCT
sflights.mandt as client,
sflights.carrid as airline_code,
sflights.carrname as airline_name,
sflights.cityto as city_to
FROM sflights;
在第二个SELECT中,我们要从itab_cities中读取数据并且实现数据库方法STRING_AGG来聚合多个城市和航空公司。为了实现这一功能我们需要基于Client,Airline Code和Name字段GROUP BY条目。写法是:
RETURN
SELECT client,
airline_code,
airline_name,
STRING_AGG(city_to, ', ' ORDER BY city_to) as cities_to
FROM :itab_cities
GROUP BY client,
airline_code,
airline_name;
注意:table function应永远有返回参数,所以记着在最后一个SELECT语句前放一个RETURN语句。另外,注意我们将字段名转换为前文中ABAP CDS Table Function声明的字段名,如果你没有提供一个合适的别名,激活的时候编译器会给出提示。
类ZCL_FLIGHTS_DEMO_CDS的最终版本是这样的:
CLASS zcl_flights_demo_cds DEFINITION
PUBLIC
FINAL
CREATE PUBLIC .
PUBLIC SECTION.
INTERFACES if_amdp_marker_hdb.
CLASS-METHODS:
flights_connections FOR TABLE FUNCTION zdemo_flights_table_function.
PROTECTED SECTION.
PRIVATE SECTION.
ENDCLASS.
CLASS zcl_flights_demo_cds IMPLEMENTATION.
METHOD flights_connections
BY DATABASE FUNCTION
FOR HDB
LANGUAGE SQLSCRIPT
OPTIONS READ-ONLY
USING sflights.
itab_cities =
SELECT DISTINCT
sflights.mandt as client,
sflights.carrid as airline_code,
sflights.carrname as airline_name,
sflights.cityto as city_to
FROM sflights;
RETURN
SELECT client,
airline_code,
airline_name,
STRING_AGG(city_to, ', ' ORDER BY city_to) as cities_to
FROM :itab_cities
GROUP BY client,
airline_code,
airline_name;
ENDMETHOD.
ENDCLASS.
在Data Preview中的结果:
英文原文:Concatenate multiple records in a single field using ABAP CDS Table Function 有少许改动
简而言之,AMDP允许开发者直接在ABAP中写数据库存储过程。
本文链接:
本文由bg游戏资讯发布于游戏通关视频,转载请注明出处:Function介绍与示例
下一篇:没有了