XQuery基数错误,将结果输出到文本文件

时间:2018-11-30 16:32:23

标签: xquery exist-db

使用XQuery 3.1(在eXistDB 4.4下),我有一个函数可以返回710个定界行的序列化输出,如下所示:

MS609-0001~ok~0001~1r~Deposition~De_Manso_Sanctarum_Puellarum_1~self~1245-05-27~Arnald_Garnier_MSP-AU~self
MS609-0002~ok~0002~1r~Deposition~De_Manso_Sanctarum_Puellarum_1~MS609-0001~1245-05-27~Guilhem_de_Rosengue_MSP-AU~MS609-0001
MS609-0003~ok~0003~1r~Deposition~De_Manso_Sanctarum_Puellarum_1~MS609-0001~1245-05-27~Hugo_de_Mamiros_MSP-AU~MS609-0001

我在另一个函数中获得了上述序列化的结果,该函数应将其作为平面文件/db/apps/deheresi/documents存储在目录depositions.txt

let $x := schedule:deposition-textfile()

return xmldb:store(concat($globalvar:URIdb,"documents"), "deposition.txt", $x)

但是当我执行xmldb:store操作时,它返回一个错误:

Description: err:XPTY0004 checking function parameter 3 
in call xmldb:store(untyped-value-check[xs:string, 
concat("/db/apps/deheresi/", "documents")], "depositions.txt", $x): 

XPTY0004: The actual cardinality for parameter 3 does not 
match the cardinality declared in the function's signature: 
xmldb:store($collection-uri as xs:string, 
$resource-name as xs:string?, 
$contents as item()) xs:string?. 

Expected cardinality: exactly one, got 710. 

如何将这些序列化的结果保存到文本文件中?

谢谢。

更新:我尝试将序列化的输出包装在<result>中,这解决了基数问题,但是它将<result>元素作为纯文本写入文件:

<result>MS609-0001~ok~0001~1r~Deposition~De_Manso_Sanctarum_Puellarum_1~self~1245-05-27~Arnald_Garnier_MSP-AU~self
MS609-0002~ok~0002~1r~Deposition~De_Manso_Sanctarum_Puellarum_1~MS609-0001~1245-05-27~Guilhem_de_Rosengue_MSP-AU~MS609-0001
MS609-0003~ok~0003~1r~Deposition~De_Manso_Sanctarum_Puellarum_1~MS609-0001~1245-05-27~Hugo_de_Mamiros_MSP-AU~MS609-0001</result>

即使我添加:

declare option exist:serialize "method=text";

2 个答案:

答案 0 :(得分:2)

我不知道您要调用的函数,但是也许您应该使用string-join()将710个字符串与一个换行符组合成一个字符串。

答案 1 :(得分:2)

错误消息似乎很清楚。 schedule:deposition-textfile()的返回类型xmldb:store()不可接受。您只需要一个字符串,而不是710。

要么更改函数的返回类型,要么在xQuery function documentation中搜索xmldb:store,以找到适合您的返回类型的替代方法。