Odata服务有时候需要同时返回多个表的结果,比如查询采购订单,需要同时返回采购订单抬头信息和明细信息。通过Odata的Assosiation 功能可以实现这个需求。
效果:一个xml同时含有抬头和行项目部分
使用/?$expand=时候,可出现以下xml效果
访问方式:
(这种只能得到item)
/sap/opu/odata/SAP/YHJWTEST_ACTIVE_SRV/ee_PO_HEADERSet(‘4100000220’)
增加/EE_PO_ITEMSet
(这种可以同时得到header和item)
/sap/opu/odata/SAP/YHJWTEST_ACTIVE_SRV/ee_PO_HEADERSet(‘4100000220’)/?$expand=EE_PO_ITEMSet
开发步骤:以采购订单为例,获取采购订单抬头和行项目
1.分别创建抬头和行项目相关的entity
两个entity需要含有共同主键,即EBELN
抬头:EE_PO_HEADER
行项目:EE_PO_ITEM
代码实现:
ee_PO_HEADERSet:
GetEntity (Read)
DATA: ls_key TYPE /iwbep/s_mgw_tech_pair,
lt_keys TYPE /iwbep/t_mgw_tech_pairs.
lt_keys = io_tech_request_context->get_keys( ). "注意大小写
READ TABLE lt_keys WITH KEY name = 'EBELN' INTO ls_key.
CHECK sy-subrc = 0.
SELECT SINGLE *
FROM ekko
INTO CORRESPONDING FIELDS OF er_entity
WHERE ebeln = ls_key-value.
GetEntitySet (Query)
DATA:lv_bukrs TYPE ekko-bukrs.
DATA:lt_ekko TYPE TABLE OF ekko.
DATA:ls_filter_pernr TYPE /iwbep/s_mgw_select_option,
ls_option TYPE /iwbep/s_cod_select_option,
ls_ee_option TYPE bapihrselemployee.
LOOP AT it_filter_select_options INTO ls_filter_pernr WHERE property = 'Bukrs'.
LOOP AT ls_filter_pernr-select_options INTO ls_option.
CLEAR ls_ee_option.
lv_bukrs = ls_option-low.
ENDLOOP.
ENDLOOP.
SELECT *
FROM ekko
UP TO 10 ROWS
INTO TABLE lt_ekko
WHERE bukrs = lv_bukrs.
MOVE-CORRESPONDING lt_ekko TO et_entityset.
ee_PO_ITEMSet:
GetEntitySet (Query)
DATA: ls_key TYPE /iwbep/s_mgw_name_value_pair.
DATA:lv_ebeln TYPE ekko-ebeln. "注意大小写
READ TABLE it_key_tab WITH KEY name = 'Ebeln'INTO ls_key.
CHECK sy-subrc = 0. lv_ebeln = ls_key-value.
SELECT *
FROM ekpo
INTO CORRESPONDING FIELDS OF TABLE et_entityset
WHERE ebeln = lv_ebeln.
2.创建association
左边填写HEADER的entity EE_PO_HEADER,右边填写ITME的entity EE_PO_ITEM,同时设置映射关系
设置相关联的字段,即前面提到的EBELN
Association结果
测试:
单独读取HEADER:
/sap/opu/odata/SAP/YHJWTEST_ACTIVE_SRV/ee_PO_HEADERSet(‘4100000220’)
使用association读取header 和item
访问路径1:
最后斜杠后面跟着的是itme的entityset的名字
/sap/opu/odata/SAP/YHJWTEST_ACTIVE_SRV/ee_PO_HEADERSet(‘4100000220’)/EE_PO_ITEMSet
这种情况下,系统只会直接调用EE_PO_ITME的Query方法,
且传入EE_PO_ITEM的Query方法中的IT_KEY_TAB为区分大小写。
返回xml只有item
访问路径2:
最后斜杠后面跟着的是itme的entityset的名字
/sap/opu/odata/SAP/YHJWTEST_ACTIVE_SRV/ee_PO_HEADERSet(‘4100000220’)/?$expand=EE_PO_ITEMSet
调用顺序:系统会先调用EE_PO_HEADER的Read方法
然后再调用EE_PO_ITME的Query方法,
且传入EE_PO_HEADER的Read方法中的Key为大写
传入EE_PO_ITEM的Query方法中的IT_KEY_TAB为区分大小写
返回xml有header和item