清除集合在 Java API 中不起作用
Clear collections is not working in Java API
我们使用的是 MarkLogic v10 和 Java API v4.1.0。
我们的要求是从特定文档中清除集合,
我们正在使用下面的代码片段来清除所有集合,
XMLDocumentManager xmlDocumentManager = client.newXMLDocumentManager();
DocumentMetadataHandle metadataHandle = new DocumentMetadataHandle();
xmlDocumentManager.readMetadata("/test/inventory", metadataHandle);
DOMHandle domHandle = new DOMHandle();
xmlDocumentManager.read("/test/inventory", domHandle);
metadataHandle.getCollections().clear();
xmlDocumentManager.write("/test/inventory", metadataHandle, domHandle);
在 运行 上面的代码片段之后,它应该从文档中删除所有集合,但它没有发生。
请帮助我完成这项工作。
复制错误的解决方案以防对其他人有用。
清除集合仅在 REST API.
的 Java API 客户端中为 in-memory DocumentMetadataHandle
在本地清除
Java API 调用的 REST API 的行为取决于 REST API 服务器更新策略的配置:
MERGE_METADATA
为客户端未发送的任何元数据类别保留现有文档的当前元数据。
OVERWRITE_METADATA
忽略现有文档的当前元数据
将更新策略更改为 OVERWRITE_METADATA 应该会产生预期的行为。
这里是 Java API 进行更改的代码:
ServerConfigurationManager configMgr = client.newServerConfigManager();
configMgr.readConfiguration();
configMgr.setUpdatePolicy(ServerConfigurationManager.UpdatePolicy.OVERWRITE_METADATA);
configMgr.writeConfiguration();
注意
服务器配置在更改之前将一直有效。通常情况下,设置后永远不会更改配置。
在 MarkLogic 服务器的最新版本中,默认更新策略从 MERGE_METADATA
更改为 OVERWRITE_METADATA
感谢 Shivling 深入研究这个问题。
我们使用的是 MarkLogic v10 和 Java API v4.1.0。 我们的要求是从特定文档中清除集合,
我们正在使用下面的代码片段来清除所有集合,
XMLDocumentManager xmlDocumentManager = client.newXMLDocumentManager();
DocumentMetadataHandle metadataHandle = new DocumentMetadataHandle();
xmlDocumentManager.readMetadata("/test/inventory", metadataHandle);
DOMHandle domHandle = new DOMHandle();
xmlDocumentManager.read("/test/inventory", domHandle);
metadataHandle.getCollections().clear();
xmlDocumentManager.write("/test/inventory", metadataHandle, domHandle);
在 运行 上面的代码片段之后,它应该从文档中删除所有集合,但它没有发生。
请帮助我完成这项工作。
复制错误的解决方案以防对其他人有用。
清除集合仅在 REST API.
的 Java API 客户端中为 in-memoryDocumentMetadataHandle
在本地清除
Java API 调用的 REST API 的行为取决于 REST API 服务器更新策略的配置:
MERGE_METADATA
为客户端未发送的任何元数据类别保留现有文档的当前元数据。OVERWRITE_METADATA
忽略现有文档的当前元数据
将更新策略更改为 OVERWRITE_METADATA 应该会产生预期的行为。
这里是 Java API 进行更改的代码:
ServerConfigurationManager configMgr = client.newServerConfigManager();
configMgr.readConfiguration();
configMgr.setUpdatePolicy(ServerConfigurationManager.UpdatePolicy.OVERWRITE_METADATA);
configMgr.writeConfiguration();
注意
服务器配置在更改之前将一直有效。通常情况下,设置后永远不会更改配置。
在 MarkLogic 服务器的最新版本中,默认更新策略从
MERGE_METADATA
更改为OVERWRITE_METADATA
感谢 Shivling 深入研究这个问题。