如何解决 XDMP-RANGEINDEX 错误?

问题描述

我们正在我们的一个数据库上运行 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!

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...