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 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

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值