SAP 通过ABAP下载CDS源码代码片段

用于下载ABAP CDS源码 

*&---------------------------------------------------------------------*
*& Report ZDOWNLOAD_CDS_13065
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
REPORT zdownload_cds_13065.

*类型定义
TYPES:
* 视图名称&源码
  BEGIN OF ty_ddlsrc,
    ddlname TYPE ddddlsrc-ddlname,
    source  TYPE ddddlsrc-source,
  END OF ty_ddlsrc,
  tt_ddlsrc TYPE STANDARD TABLE OF ty_ddlsrc,

* 源码
  BEGIN OF ty_source,
    source TYPE ddddlsrc-source,
  END OF ty_source,
  tt_source TYPE STANDARD TABLE OF ty_source.

DATA:
  gt_ddlsrc TYPE tt_ddlsrc,
  gs_ddlsrc TYPE ty_ddlsrc,
  gt_source TYPE tt_source,
  gs_source TYPE ty_source.

DATA:
  gv_filename TYPE string,
  gv_filetype TYPE char10.

*&---------------------------------------------------------------------*
*   Selection Screen
*&---------------------------------------------------------------------*
PARAMETERS p_dev TYPE tadir-devclass.             "包名

*&---------------------------------------------------------------------*
*   Start of selection
*&---------------------------------------------------------------------*
START-OF-SELECTION.
* 根据包名获取CDS视图及源码
  SELECT d~ddlname                                "视图名
         d~source                                 "源码
    FROM tadir AS t
   INNER JOIN ddddlsrc AS d
      ON t~obj_name = d~ddlname
    INTO TABLE gt_ddlsrc
   WHERE t~pgmid    = 'R3TR'
     AND t~object   = 'DDLS'
     AND t~devclass = p_dev.                      "包名

  IF sy-subrc = 0.
    WRITE ' File downloaded successfully'.
  ENDIF.
*&---------------------------------------------------------------------*
*   End of selection
*&---------------------------------------------------------------------*
END-OF-SELECTION.
  LOOP AT gt_ddlsrc INTO gs_ddlsrc.
    CONCATENATE 'D:\CDS_Download\' gs_ddlsrc-ddlname '.txt' INTO gv_filename.
    gs_source-source = gs_ddlsrc-source.
    APPEND gs_source TO gt_source.

    CALL FUNCTION 'GUI_DOWNLOAD'
      EXPORTING
        filename              = gv_filename
        filetype              = 'ASC'
        write_field_separator = 'X'
      TABLES
        data_tab              = gt_source.

    CLEAR:
      gv_filename,
      gt_source.
  ENDLOOP.

### 如何定位 ABAP CDS View 所基于的原始旧表 在 SAP ABAP 中,CDS (Core Data Services) 视图可以通过多种方式与底层数据库表建立关联。为了找到某个特定 CDS 视图所基于的原始旧表,可以按照以下逻辑分析: #### 1. **查看 CDS 定义** 在 ABAP Development Tools (ADT) 中打开目标 CDS 视图的源代码文件。通常情况下,CDS 视图会通过 `ASSOCIATION` 或者直接从某张数据库表继承字段。如果视图是从一张具体表派生而来,则可以直接看到该表名称。 示例代码如下: ```abap @AbapCatalog.sqlViewName: 'ZMY_CDS_VIEW' define view Z_MY_CDS_VIEW as select from MARA { MATNR, MTART, MEINS } ``` 上述例子中,可以看到 CDS 视图 `Z_MY_CDS_VIEW` 是基于标准表 `MARA` 创建的[^2]。 --- #### 2. **利用注解追踪** 如果 CDS 视图使用了某些特殊注解(例如 `@ObjectModel.textTable`),这些注解可能指定了其他辅助表或扩展表的信息。因此,在阅读 CDS 源码时需要注意是否有类似的注解存在。 示例: ```abap @ObjectModel.textTable: { key: 'MATNR', textAttribute: 'MAKTX', languageField: 'SPRAS' } define view Z_MY_CDS_VIEW as select from MARA { ... } ``` 这里表明,对于物料描述 (`MAKTX`) 的多语言支持来自另一张表 `MAKT`[^3]。 --- #### 3. **借助 SE11 和 DD02L 查看依赖关系** 使用事务代码 `SE11` 输入 CDS 视图名称并进入技术细节页面。在此处可以选择 “Dependencies” 菜单项以显示所有相关联的对象列表,其中包括基础表和其他引用实体。 此外还可以查询系统元数据表 `DD02L` 来获取更详细的映射信息。执行 SQL 查询命令如下所示: ```sql SELECT * FROM DD02L WHERE TABNAME = 'ZMY_CDS_VIEW'. ``` 结果集中将包含关于物理存储结构以及对应的实际表格名等重要参数[^4]。 --- #### 4. **激活后的虚拟表表现形式** 当一个 CDS 视图被成功编译并部署到生产环境之后,默认会在后台生成对应的 Open SQL 兼容版本或者 Native SQL 实现方案。此时可通过调用函数模块 `REPO_READ_TABLE` 并传入相应参数来动态提取其内部定义内容及其背后支撑的真实数据载体[^1]。 --- #### 总结 综上所述,要准确定位任何给定 ABAP CDS View 对应的基础旧版数据库表,最有效的方法就是结合开发工具内的直观展示功能同必要的脚本编写技巧共同完成任务。 ```abap REPORT z_find_base_table. DATA: lv_cds_name TYPE string VALUE 'Z_MY_CDS_VIEW'. CALL FUNCTION 'REPO_READ_TABLE' EXPORTING NAME = lv_cds_name * IMPORTING * RESULT = TABLES FIELDS = DATA(lt_fields). ``` 上述示例展示了如何自动化检索指定 CDS 视图的相关属性集合。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

DeveloperMrMeng

觉得有用的佛系投币哦

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

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

打赏作者

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

抵扣说明:

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

余额充值