如何实现S/4HANA和CRM费奥里应用的搜索分页

技术如何进行S/4HANA和CRM Fiori应用的搜索分页实现这期内容当中小编将会给大家带来有关如何进行S/4HANA和CRM Fiori应用的搜索分页实现,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希

本期,边肖将为您带来关于如何实现S/4HANA和CRM费奥里应用程序的搜索分页的信息。文章内容丰富,从专业角度进行分析和描述。希望你看完这篇文章能有所收获。

如何在S/4HANA和CRM中实现原生费奥里应用的搜索分页?

选择S/4HANA中的产品主文档和我在CRM中的机会作为示例进行介绍。

S/4HANA费奥里应用程序的搜索分页实现

点击搜索按钮后,默认返回前25个命中产品,显示命中产品总数:140个。

br font-size :16 px;白色空间space:normal背景-color : # FFFFFF;' /

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

这种分页效果是通过OData请求的参数$skip=0top=25实现的。点击总数140由另一个参数$inlinecount显示,它的后台实现原理类似于ABAP Open SQL中的SELECT COUNT(*)。

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

观察Chrome开发工具对此请求的响应,只返回了25条记录。

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

将搜索结果列表滚动到底部,发现另一个OData请求自动发出:

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

此请求的标头参数为$skip=25top=25,因此只能从后台提取第26到第50个产品:

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

我的博客SAP费奥里中的列表是如何进行惰性加载的?我解释了$skip的序列值如何递增0,25,50,75.都是在前台生成的。

在这篇博客中,我将重点介绍分页搜索的后台实现。

假设我重复将搜索结果滚动到底部的动作三次,我可以观察到通过ST05有三个数据库读取请求,每个请求返回25条记录。

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

单击此按钮查看哪一行ABAP代码启动了数据库读取请求:

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

$skip和$top的值从前台传输到后台,后台的方法CL _ Sadl _ GW _ generic _ DPC ~ _ get _ entity set的输入参数io_query_option可以观察3360。

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

起始行的索引值等于$skip参数的值加上1。

如何进行S/4HANA和CRM  Fiori应用的搜索分页实现

实际读数

分页在后台的实现:通过ABAP关键字OFFSET实现。

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

该OFFSET的值通过方法CL_SADL_SQL_STATEMENT~GET_SECTIONS_FOR_SELECT内一个较复杂的table表达式来决定出来:

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

首先得出表达式lt_sections[ type = cl_sadl_sql_statement=>co_type-page ]-from的值:99.

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

再从内表mt_parts取出第99条记录,从其字段value2得出最终offset值75。

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

CRM Fiori应用的搜索分页实现

前台的逻辑和S/4HANA的Fiori应用完全一致。

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

该参数传至后台,存储在参数is_paging里:

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

至于后台的分页搜索,My opportunities应用并未使用ABAP OPEN SQL里的关键字OFFSET。相反地,所有匹配记录的GUID都通过One Order的搜索API返回:

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

多余的记录,即那些不在$skip和$top定义的参数之内的都被DELETE丢弃:

如何进行S/4HANA和CRM Fiori应用的搜索分页实现

该实现或许不如S/4HANA采用OFFSET方式实现得直接,但是因为从数据库返回的仅仅是命中opportunity的GUID,因此也不会有太多额外的开销。

上述就是小编为大家分享的如何进行S/4HANA和CRM Fiori应用的搜索分页实现了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/151652.html

(0)

相关推荐

  • 圆锥的体积公式是什么,圆锥的面积和体积计算公式

    技术圆锥的体积公式是什么,圆锥的面积和体积计算公式一个圆锥所占空间的大小圆锥的体积公式是什么,叫做这个圆锥的体积.一个圆锥的体积等于与它等底等高的圆柱的体积的1/3根据圆柱体积公式V=Sh(V=πr^2h),得出圆锥体积

    生活 2021年10月21日
  • 如何理解Java设计模式的代理模式

    技术如何理解Java设计模式的代理模式这篇文章将为大家详细讲解有关如何理解Java设计模式的代理模式,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、代理模式定义  为其

    攻略 2021年10月23日
  • 如何使用hystrix的配置

    技术如何使用hystrix的配置这篇文章主要介绍“如何使用hystrix的配置”,在日常操作中,相信很多人在如何使用hystrix的配置问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使

    攻略 2021年10月21日
  • oneyear,oneyearago是什么意思

    技术oneyear,oneyearago是什么意思oneyearago 的中文意思是“一年前,”但三个单词不能一起连写,正确的写法应该是oneyear: one year ago. 这句短语可用在句首或句尾,在时间上通常

    生活 2021年10月21日
  • css中em标签如何去除斜体样式

    技术css中em标签如何去除斜体样式这篇文章主要介绍css中em标签如何去除斜体样式,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 在css中,可以利用“font-st

    攻略 2021年12月11日
  • Excel如何录入权限矩阵

    技术Excel如何录入权限矩阵这篇文章给大家介绍Excel如何录入权限矩阵,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 领导要录入一个权限矩阵的数据入数据库,问我有没有

    攻略 2021年11月16日