问题描述
我们正在我们的一个数据库上运行 reindex,大约 400 GB。我们看到下面的调试日志条目:-
2021-01-24 16:13:55.705 Debug: IndexerEnv::putRangeIndex: XDMP-RANGEINDEX: Range index error: double "": XDMP-LEXVAL: Invalid lexical value ""
2021-01-24 16:13:55.715 Debug: IndexerEnv::putRangeIndex: XDMP-RANGEINDEX: Range index error: double "": XDMP-LEXVAL: Invalid lexical value ""
看起来其中一个索引没有设置正确的标量类型,或者文档中的元素具有无效值?我们如何解决这个问题?任何建议
解决方法
您运行的是什么版本的 MarkLogic?使用 MarkLogic 10.0-5 进行的快速测试在错误消息中显示一个 uri:
2021-01-25 09:36:01.636 调试:IndexerEnv::putRangeIndex:XDMP-RANGEINDEX:范围索引错误:int fn:doc("/test/doc1.xml")/root/foo: XDMP-LEXVAL : 无效的词法值“bar”
否则,您将需要检查您拥有哪些类型为 double
的范围索引,并尝试 XPath 是否可以显示哪些文档有问题。类似的东西:
subsequence(collection()[//path/to/double = ''],1,10) ! xdmp:node-uri(.)
不要一路抓住它们,但抓住前 10 个应该是可行的。可能会让你知道去哪里找。
HTH!