0

我正在使用 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;
    }

但它总是返回空列表。

我还尝试使用下一个查询进行查询:

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]

但结果还是一样。我做错了什么?

感谢您的任何帮助。

4

1 回答 1

0

存在一个已知问题,即数据库元数据节点未自动编制索引。一个简单的解决方法是将 JCR 会话的getWorkspace()实例org.modeshape.jcr.api.Workspace强制转换为(ModeShape 工作区的公共 API)并调用该reindex(String path)方法并传入数据库目录节点(或如果需要,则为祖先)的路径。

于 2012-08-30T11:33:42.687 回答