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服务同时返回多个表数据
版权声明:本文标题:Odata服务同时返回多个表数据 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/jishu/1732351208h1533112.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论