SAP ABAP CDS View 源代码搜索工具

笔者之前的教程文章,分享了笔者原创的一个 CDS View 源代码行数统计工具:

有个朋友问我 ABAP Development Tool 里关于搜索 CDS View 源代码的问题。

笔者尝试了一下,ABAP Development Tool 提供的 ABAP Source Search 功能,只支持 ABAP 报表和 ABAP 类里源代码的搜索。

这个结果也不难预料,因为 ABAP 系统里,ABAP 报表和 ABAP 类,其源代码存储在数据库表 REPOSRC 里:

### 如何定位 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
发出的红包

打赏作者

汪子熙

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值