在ABAP应用里,我们application developer用Open SQL访问database, 这些Open SQL会被Database interface转换成database provider specific的SQL然后执行。
CRM和C4C里还支持enterprise search / simple search,
实现原理实际上是application call一个RFC到TREX server上拿到查询结果。
Hybris里有类似的功能:FlexibleSearch service
FlexibleSearch service使用Hybris自己发明的一套基于SQL syntax的language,类似ABAP的open SQL.
看个例子:
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 (?,?,?,?,?,?,?) )
上述语句里7个问号代表的变量的值,可以在execution statistics里找到:
其实就是7个catalog:
搜索结果,对应两条记录:
这两条记录同样可以在backoffice里搜索得到:
要获取更多Jerry的原创文章,请关注公众号"汪子熙":