目前我正在尝试使用 Java API 从我的 MarkLogic 服务器获取数据 (XML)。
因此我添加了命名空间:
NamespacesManager nsManager = client.newServerConfigManager()
.newNamespacesManager();
nsManager.addPrefix("document",
"http://test/dummy/master/doc");
...
之后我尝试了以下操作:
DatabaseClient client = DatabaseClientFactory.newClient("IP_ADDRESS",
PORT, user, password, Authentication.DIGEST);
SearchHandle handle = new SearchHandle();
QueryManager queryMgr = client.newQueryManager();
KeyValueQueryDefinition query = queryMgr.newKeyValueDefinition();
query.put(
queryMgr.newElementLocator(new QName("doc:id")),
"1439-1074");
SearchHandle resultsHandle = queryMgr.search(query, handle);
System.out.println("results: " + resultsHandle.getTotalResults());
// System.out.println("Matched "+resultsHandle.getTotalResults()+
// " documents with '"+query.getCriteria()+"'\n");
// iterate over the result documents
MatchDocumentSummary[] docSummaries = resultsHandle.getMatchResults();
System.out.println("Listing "+docSummaries.length+" documents:\n");
所有作品;我得到了结果,但它们不包含 XML 文档(只是文档的 URI)。是否可以使用此查询获取 XML 结果,或者我是否必须提交第二个查询,例如:
JSONDocumentManager docMgr = client.newJSONDocumentManager();
StringHandle doc = docMgr.read(uri, new StringHandle());