定义CDS表函数功能

在创建CDS时,有一种是定义Define Table Function的CDS,使用此Table Function 的CDS,我觉得主要是使用在更为复杂的CDS中,比如不能简单使用表关联来取得数据时,可使用此定义CDS,通过ABAP Managed Database Procedures (AMDP)创建ABAP CDS Table Function,并调用自定义类方法(此时的类方法,相当于在HANA DB 的存储过程),来处理生成DLL数据,然后再生成相关的其它CDS,以便于消费层(比如ODATA)使用。如图。

定义CDS表函数功能 - 第1张  | 优通SAP
模板定义带参数的表功能

此功能使用的是SAP 新AMDP(ABAP托管数据库过程)的基本功能,在这里可以查看AMDP更多介绍。

定义CDS表函数功能 - 第2张  | 优通SAP
CDS TABLE 功能的基本思想

上图说明了CDS表功能的基本思想:

  • CDS表功能通过关键字DEFINE TABLE FUNCTION在DDL源中定义。(就像CDS视图是通过关键字DEFINE VIEW在DDL Sources中定义的一样。)
  • CDS表函数的定义通过添加IMPLEMENTED BY来引用现有的AMDP函数。
  • ABAP程序(或CDS视图)可以在SELECT语句的from子句中将CDS表功能用作数据源,就像对CDS视图,数据库视图或透明表一样。
  • CDS框架通过在数据库上调用分配的函数来执行CDS表函数中的SELECT。

1.创建CDS表功能

开发CDS表功能时,以正确的顺序进行操作是最重要的。

1.1.为CDS表功能创建DDL源

  • 使用带有参数的模板定义表功能
  • 定义参数(可选)并返回值(不要忘记客户字段!)
  • 将IMPLEMENTED BY之后的信息保留为itis(未经语法检查检查)
  • 激活DDL源
定义CDS表函数功能 - 第3张  | 优通SAP
CDS表功能的示例定义

1.2.使用AMDP方法创建AMDP类

  • 创建一个全局类并实现接口IF_AMDP_MARKER_HDB
  • 定义带有添加的FOR TABLE FUNCTION的公共静态方法
  • 将方法实现为AMDP函数
  • 激活全局类
定义CDS表函数功能 - 第4张  | 优通SAP
CDS的AMDP功能的定义

不带参数定义实现CDS表功能的AMDP方法。而是使用FOR FOR TABLE FUNCTION…。然后从CDS表函数获取AMDP方法的签名.

1.3.AMDP功能

  • AMDP函数使用AMDP类中Method语句的新增加的BY DATABASE FUNCTION。
  • 与AMDP过程实现不同,AMDP函数实现没有导出或更改参数。它们只有一个表格返回值。
  • ABAP程序不能直接调用AMDP函数实现。但是可以从其他AMDP函数或过程中调用它们。
定义CDS表函数功能 - 第5张  | 优通SAP
AMDP函数的示例定义

上面的示例显示了AMDP类的定义。AMDP方法FUNCTION旨在由数据库功能实现。它被定义为一种功能方法,即,它仅具有一个表格返回参数,并且仅具有导入参数。

注意:一旦数据库功能实现了此功能方法,就不能再在ABAP中调用它。

定义CDS表函数功能 - 第6张  | 优通SAP
AMDP功能的示例实现

上面的示例显示了AMDP函数的实现。

  • 使用BY DATABASE FUNCTION代替BY DATABASE PROCEDURE。其余的添加与数据库过程具有相同的含义和值。
  • 在数据库功能的脚本中,语句RETURN是必需的。RETURN语句定义return参数的值。

1.4.完成CDS表功能的定义

  • 在IMPLEMENTED BY之后输入AMDP类和AMDP方法
  • 激活DDL源
  • 在数据预览中测试CDS表功能
  • 您必须先创建并激活DDL Source!
  • 这是因为在定义带有FOR TABLE FUNCTION的AMDP方法时,需要现有的,已激活的CDS Table Function。
  • 另一方面,在AMDP方法之前激活DDL Source没问题。语法检查在IMPLEMENTED BY之后接受不存在的类和/或方法。
  • 一旦完成了AMDP函数的实现,请返回CDS表函数定义并更新AMDP类的名称和AMDP方法。

上面的示例显示了CDS表函数的定义。从外部看,它看起来像CDS视图的定义,带有输入参数name_in和具有三个字段mandt,id和name的元素列表。