MarkLogic触发器声明-我在这方面做错了什么



我涉足MarkLogic,但并不轻松。最近我一直在尝试触发器,但进展也同样糟糕。我希望这里有人能给我一些建议,告诉我在这里到底做错了什么。

遵循上的MarkLogic社区教程https://docs.marklogic.com/guide/app-dev/triggers#id_66092我命名了我的数据库测试,并将其列为自己的触发器数据库。然后,我对测试数据库运行了这个查询:

xquery version "1.0-ml"
import module namespace trgr="http://marklogic.com/xdmp/triggers" 
 at "/MarkLogic/triggers.xqy";
trgr:create-trigger("myTrigger", "Simple trigger example", 
  trgr:trigger-data-event(
  trgr:directory-scope("/myDir/", "1"),
  trgr:document-content("create"),
  trgr:post-commit()),
  trgr:trigger-module(xdmp:database("test"), "/modules/", "log.xqy"),
  fn:true(), xdmp:default-permissions() );

它返回了14463004257041262559,我可以确认这是正确的URI。

然后,我使用以下查询按照指示定义了/modules/log.xqy

xquery version '1.0-ml';
(: evaluate this against the database specified 
in the trigger definition (test in this example)
:)
xdmp:document-insert("/modules/log.xqy", 
  text{ "
xquery version '1.0-ml';
import module namespace trgr='http://marklogic.com/xdmp/triggers' 
   at '/MarkLogic/triggers.xqy';
declare variable $trgr:uri as xs:string external;
xdmp:log(fn:concat('*****Document ', $trgr:uri, ' was created.*****'))"
}, xdmp:permission('app-user', 'execute'))

然后我确认了它的存在,并且与引号之间的文本完全匹配。

但是,当我运行xdmp:document-insert("/myDir/test.xml", <test/>)时,文档已经创建,并且没有发生任何其他事情。当我打开ErrorLog.txt时,它应该附加的文本不在那里。

考虑到可能是我找错了地方,我还添加了fn:doc("/modules/log.xqy"),这样它就会显示它是否运行,但将新文档插入正确的目录从未提示触发器执行任何操作。

我希望你的一个号码能告诉我我做错了什么,因为这很令人沮丧。我等待你的援助。

您说您创建了modules/log.xqy,但代码引用了/modules/log.xqy。这两个URI确实不同。

最新更新