如何实现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)

相关推荐

  • keka解压后怎么安装不了软件了(keka解压软件安装说明)

    技术Keka for Mac压缩解压工具怎么用今天就跟大家聊聊有关Keka for Mac压缩解压工具怎么用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Keka

    攻略 2021年12月24日
  • 桂花的样子描写,描写桂花样子,赞扬他的精神的段落

    技术桂花的样子描写,描写桂花样子,赞扬他的精神的段落打我小时候便有了这棵桂花树。它不是太壮桂花的样子描写,也不是太高,却算得上是高龄了。想想小时候,真的很“幼稚”。奶奶说,那就是夜晚天上月亮里的那棵树哩!而那时天真的我却

    生活 2021年10月27日
  • google my map(google map application)

    技术如何申请Google Map API v2 的API key如何申请Google Map API v2 的API key,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可

    攻略 2021年12月24日
  • 抖音刷赞网站推广平台,抖音刷赞专业平台?

    技术抖音刷赞网站推广平台,抖音刷赞专业平台?要想刷赞的话,内容的创作,后期的运营是关键,看那些大段短15秒钟的视频就能如此吸赞,背后是一整套运作流程的支持。
    一、热门视频带来的流量,一般一个视频在上热之后会增加大量的赞丝

    测评 2021年11月9日
  • oracle的ddl与dml(oracle中ddl语句)

    技术ORACLE sid,pid,spid和v$session中的saddr,paddr和taddr示例分析本篇文章为大家展示了ORACLE sid,pid,spid和v$session中的saddr,paddr和tad

    攻略 2021年12月17日
  • Windows如何实现任务计划隐藏显示黑窗口

    技术Windows如何实现任务计划隐藏显示黑窗口小编给大家分享一下Windows如何实现任务计划隐藏显示黑窗口,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Windows 任务计划隐藏显示黑窗口,主要通

    攻略 2021年11月18日