cds view join和association
1:创建两张表:ztt_teacher01 和ztt_teacher02 用于 cds view中的join和association
2:创建两个cds view:ztt_teacher01_id_name和 ztt_teacher02_id_salary
3: 在ztt_teacher01_id_name 中使用连接对数据表进行查询
@AbapCatalog.sqlViewName: 'TEACHER01' @AbapCatalog.compiler.compareFilter: true @AbapCatalog.preserveKey: true @AccessControl.authorizationCheck: #CHECK @EndUserText.label: 'teacher table have id,name field' define view ztt_teacher01_id_name as select from ztt_teacher01 as t01 left outer join ztt_teacher02 as t02 on t01.id = t01.id { t01.id, name, salary }
结果如下:
4: ztt_teacher02_id_salary
@AbapCatalog.sqlViewName: 'TEACHER02' //名字,改名字用于外部交互。 @AbapCatalog.compiler.compareFilter: true @AbapCatalog.preserveKey: true @AccessControl.authorizationCheck: #CHECK @EndUserText.label: 'teacher table has id_salary' define view ztt_teacher02_id_salary as select from ztt_teacher02 { id, salary }
5: ztt_teacher01_id_name 使用association
@AbapCatalog.sqlViewName: 'TEACHER01' @AbapCatalog.compiler.compareFilter: true @AbapCatalog.preserveKey: true @AccessControl.authorizationCheck: #CHECK @EndUserText.label: 'teacher table have id,name field' define view ztt_teacher01_id_name as select from ztt_teacher01 as t01 association [..] to teacher02 as asso02 on $projection.id = asso02.id { t01.id, name, asso02.salary }
结果如下:
因为association 涉及到两个cds view,因此不能使用测试环境对ztt_teacher01_id_name 进行mock 数据。但是可以对cds view 进行数据库查询。步骤如下:
1:将cds view ztt_teacher01_id_name 中的view 定义改为:
@AbapCatalog.sqlViewName: 'TEACHER01' @AbapCatalog.compiler.compareFilter: true @AbapCatalog.preserveKey: true @AccessControl.authorizationCheck: #CHECK @EndUserText.label: 'teacher table have id,name field' define view ztt_teacher01_id_name as select from ztt_teacher01 as t01 association [..] to teacher02 as asso02 on $projection.id = asso02.id { t01.id, name, asso02.salary, asso02 //将另一个cds view 作为 ztt_teacher01_id_name 的一个属性。 }
2:定义查询语句,对teacher02 中的字段salary进行查询:
method GET_TEACHER_SALARY_BY_ID. SELECT SINGLE \asso02-salary FROM ztt_teacher01_id_name WHERE ztt_teacher01_id_name~id = @iv_id INTO @ev_salary. endmethod.
3: unit test 调用查询语句。
METHOD Test_teacher_salary_assocation. TYPES: BEGIN OF teacher_association, id TYPE ztt_teacher01-id, name TYPE ztt_teacher01-name, salary TYPE ztt_teacher02-salary, end of teacher_association. data lt_TEST_DATA TYPE STANDARD TABLE OF teacher_association. . DATA lv_salary TYPE i. * lt_TEST_DATA = VALUE #( " 对association不能插入假数据了,因为底层有两个 view。而创建的 test_environment只是对一个view进行虚拟。 * ( id = '1' name = 'lisi' salary = 10 ) " the first data adds to cds view * ( id = '2' name = 'zhaoliu' salary = 20 ) " other data with same name will be abandoned. * ). * lv_cds_test_environment->insert_test_data( i_data = lt_TEST_DATA ). CALL METHOD f_cut->GET_TEACHER_SALARY_BY_ID( "调用方法,直接对cds view进行查询,该cds view 直接查询数据库中的数据。 EXPORTING iv_id = lv_id IMPORTING ev_salary = lv_salary ). cl_abap_unit_assert=>assert_equals( act = lv_salary exp = msg = 'the name is not expected!' ). ENDMETHOD.
成功执行。
cds view join和association的更多相关文章
- 如何用ABAP代码读取CDS view association的数据
我有如下一个CDS view, 这个view的数据来自CRMD_ORDERADM_H, 定义了一个名称为_statushelp的association, 指向了另一个CDS view Z_C_Stat ...
- Inner Join, Left Outer Join和Association的区别
测试用的CDS视图的源代码,第8行用Inner Join连接TJ02T, 后者存放了所有系统状态的ID和描述. Inner Join测试结果:对于那些在TJ02T里没有维护描述信息的状态,它们不会出现 ...
- CDS view注解解析 - @Environment.systemField
下面的CDS view使用到了@Environment.systemField这个注解,定义了两个参数#SYSTEM_LANGUAGE和#USER. 这个view从CRM物料主数据的产品抬头表COMM ...
- Create Fiori List App Report with ABAP CDS view – PART 1
From Create Fiori List App Report with ABAP CDS view – PART 1 In this blog, I am going to show How C ...
- 使用CDS view开发SAP Marketing contact的facet追溯工具
这篇SAP社区博客里,我的一位同事介绍了SAP Marketing里contact facet数据模型的存储表: https://blogs.sap.com/2016/07/01/how-does-s ...
- 一个使用CDS VIEW 的 DEMO
一个使用CDS VIEW 的demo REPORT demo_cds_currency_conversion. CLASS demo DEFINITION. PUBLIC SECTION. CLASS ...
- Jerry的CDS view自学系列
My CDS view self study tutorial - part 1 how to test odata service generated by CDS view https://blo ...
- Jerry的通过CDS view + Smart Template 开发Fiori应用的blog合集
S4/HANA里有一个新的UI框架叫做Smart template, 配合ABAP后台的CDS view技术,能够让developer以Metadata driven的方式来开发Fiori应用, 这种 ...
- cds view 创建和调用
cds view 是一个core data service, 能够将数据库表虚拟化为一个虚拟表(double).因为各个使用sap的公司,使用的数据库数据是不同的,所以提供一个数据库的虚拟. 通过向 ...
随机推荐
- Python2.x与3.x版本区别
Python2.x与3.x版本区别 1.print 函数 print语句没有了,取而代之的是print()函数. Python 2.6与Python 2.7部分地支持这种形式的print语法.在Pyt ...
- Linux 公网IP和内网IP,Dubbo提供者注册到了内网IP上怎么处理!
1.将Linux的localhost 改为公网IP: 改完以后重启网卡,并刷新Hosts: 2.将提供者和消息者的Dubbo 都改为公网IP: 3.开放端口:
- WPS Office手机版调用接口代码指导帖之二 [复制链接]
原文链接:http://bbs.wps.cn/thread-22349340-1-1.html 从V5.1版本开始,WPS移动版本提供了额外的功能,可以供第三方程序通过集成的方式调用“WPS移动版”打 ...
- 【2019年04月22日】A股最便宜的股票
太钢不锈(SZ000825) - 当前便宜指数:170.67 - 滚动扣非市盈率PE:4.37 - 滚动市净率PB:0.98 - 动态年化股息收益率:4.79%- 太钢不锈(SZ000825)的历 ...
- 转:spring配置文件中xsd引用问题
来自:http://blog.csdn.net/dingqinghu/article/details/46758671
- JS精准倒计时(支持自定义模板)
/** * 倒计时 Create By TuJia @2017.10.17 * 使用方法: * leftTimer.run(container[,theme][,callback]); * * 支持 ...
- 【Static Program Analysis - Chapter 4】格理论(Lattice Theory)与程序分析
# 从一个例子说起, **任务:给定这样一段代码,假设我们想分析出这段代码中,每个数值型变量和表达式的符号,即正数,负数或0.** 此外,还有可能出现两种情况就是: 1.我们无法分析出结果,即我们无法 ...
- 转载:margin外边距合并问题以及解决方式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Ext-JS-Classic-Demo 面向pc端示例
基于Ext Js 6.5.1 面向pc端示例,低于此版本可能存在兼容问题,慎用 已忽略编译目录,请自行编译运行 Sencha Cmd 版本:v6.5.1.240 git地址:https://githu ...
- 【漏洞复现】Tomcat CVE-2017-12615 远程代码执行漏洞
漏洞描述 [漏洞预警]Tomcat CVE-2017-12615远程代码执行漏洞/CVE-2017-12616信息泄漏 https://www.secfree.com/article-395.html ...