ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

时间:2022-01-30 02:36:26

在ABAP应用里,我们application developer用Open SQL访问database, 这些Open SQL会被Database interface转换成database provider specific的SQL然后执行。

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

CRM和C4C里还支持enterprise search / simple search,

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

实现原理实际上是application call一个RFC到TREX server上拿到查询结果。

Hybris里有类似的功能:FlexibleSearch service

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

FlexibleSearch service使用Hybris自己发明的一套基于SQL syntax的language,类似ABAP的open SQL.

看个例子:

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

select * from {Product} where {code} = ‘cris03‘

这条flexible search语言被预编译成和SQL语句语法类似的查询语句:
SELECT * FROM products item_t0 WHERE ( item_t0.p_code = ‘cris03‘) AND (item_t0.TypePkString IN (?,?,?,?,?,?,?) )

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

上述语句里7个问号代表的变量的值,可以在execution statistics里找到:

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

其实就是7个catalog:

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

搜索结果,对应两条记录:

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

这两条记录同样可以在backoffice里搜索得到:

ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介

要获取更多Jerry的原创文章,请关注公众号"汪子熙":
ABAP的OPEN SQL和Hybris Commerce的Flexible Search简介