admin 管理员组

文章数量: 887006

Odata服务同时返回多个表数据

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 ekkoUP TO 10 ROWSINTO TABLE lt_ekkoWHERE 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 ekpoINTO CORRESPONDING FIELDS OF TABLE et_entitysetWHERE 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


本文标签: Odata服务同时返回多个表数据