如何在 Optic API 中使用 optic-fn, optic-json, optic-xdmp, optic-xs

How to use optic-fn, optic-json, optic-xdmp, optic-xs in Optic API

我们正在探索 Optic API 并进行一些 POC,以用 Optic API 查询替换我们现有的代码。

作为我们新要求的一部分,我们要使用 optic-fn、optic-json、optic-xdmp、optic-xs、 我们花了很多时间使用 optic-fn、optic-json、optic-xdmp、optic-xs 查找示例或示例代码,但找不到任何示例代码供参考。

任何人都可以帮助我们为每个(optic-fn、optic-json、optic-xdmp、optic-xs)提供示例代码片段,这样对我们很有帮助吗?

感谢任何帮助。

在 XQuery 中,您不仅要导入核心 Optic 库

import module namespace op="http://marklogic.com/optic"
  at "/MarkLogic/optic.xqy";

还有提供查询中所需的任何表达式函数的库。使用以下库的任意组合:

import module namespace octs="http://marklogic.com/optic/expression/cts"
  at "/MarkLogic/optic/optic-cts.xqy"; 
import module namespace ofn="http://marklogic.com/optic/expression/fn"
  at "/MarkLogic/optic/optic-fn.xqy";
import module namespace ogeo="http://marklogic.com/optic/expression/geo"
  at "/MarkLogic/optic/optic-geo.xqy";
import module namespace ojson="http://marklogic.com/optic/expression/json"
  at "/MarkLogic/optic/optic-json.xqy";
import module namespace omap="http://marklogic.com/optic/expression/map"
  at "/MarkLogic/optic/optic-map.xqy";
import module namespace omath="http://marklogic.com/optic/expression/math"
  at "/MarkLogic/optic/optic-math.xqy";
import module namespace ordf="http://marklogic.com/optic/expression/rdf"
  at "/MarkLogic/optic/optic-rdf.xqy"; 
import module namespace osem="http://marklogic.com/optic/expression/sem"
  at "/MarkLogic/optic/optic-sem.xqy"; 
import module namespace ospell="http://marklogic.com/optic/expression/spell"
  at "/MarkLogic/optic/optic-spell.xqy";
import module namespace osql="http://marklogic.com/optic/expression/sql"
  at "/MarkLogic/optic/optic-sql.xqy"; 
import module namespace oxdmp="http://marklogic.com/optic/expression/xdmp"
  at "/MarkLogic/optic/optic-xdmp.xqy"; 
import module namespace oxs="http://marklogic.com/optic/expression/xs"
  at "/MarkLogic/optic/optic-xs.xqy";

此后,您以相同的方式调用函数,重要的区别在于参数不仅可以包含文字,还可以包含 op:col("NAME") 以指定列值或来自其他嵌套表达式的 return 值功能如下:

=> op:where(
    ofn:starts-with(
       op:col("col1"),
       ofn:substring-before(op:col("col2"), "prefix")
       )
   )

注意在执行查询期间对值进行操作时,您只能使用 Optic 表达式库中的函数。要在构建计划时对作为参数传递的文字值进行操作,请使用普通函数。

特别是,cts:query() 参数总是在 cts 命名空间而不是 octs 命名空间中构建。

有关哪些函数公开为表达式函数以及表达式函数如何在 SJS 中公开的详细信息,另请参阅:

希望对您有所帮助,