我使用的是Modeshape和modeshape-connector-jdbc-metadata。我想要获取存储中表示表的所有节点。节点具有[mj:catalog]混合类型。
我正在使用下一段代码查询存储:
public List getDatabases() throws RepositoryException {
// Obtain the query manager for the session ...
QueryManager queryManager = dbSession.getWorkspace().getQueryManager();
// Create a query object ...
Query query = queryManager.createQuery("SELECT * FROM [mj:table]"
, Query.JCR_SQL2);
// Execute the query and get the results ...
QueryResult result = query.execute();
// Iterate over the nodes in the results ...
NodeIterator nodeIter = result.getNodes();
List stringResult = new ArrayList();
while (nodeIter.hasNext()) {
stringResult.add(nodeIter.nextNode().getName());
}
return stringResult;
}但它总是返回空列表。
我还尝试使用next queries进行查询:
SELECT unst.*, tbl.* FROM [nt:unstructured] AS unst
JOIN [mj:table] AS tbl ON ISSAMENODE(unst,tbl)SELECT * FROM [nt:unstructured] WHERE [jcr:mixinTypes] = [mj:table]但结果仍然是一样的。我哪里做错了?
谢谢你的帮助。
发布于 2012-08-30 19:33:43
存在一个已知问题,即数据库元数据节点不是自动索引的。一种简单的解决方法是将JCR会话的getWorkspace()实例强制转换为org.modeshape.jcr.api.Workspace (ModeShape工作区的公共API ),然后调用reindex(String path)方法并传入数据库编目节点(如果需要,也可以是祖先)的路径。
https://stackoverflow.com/questions/12192294
复制相似问题