首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Modeshape查询mixinTypes

Modeshape查询mixinTypes
EN

Stack Overflow用户
提问于 2012-08-30 15:51:54
回答 1查看 406关注 0票数 0

我使用的是Modeshape和modeshape-connector-jdbc-metadata。我想要获取存储中表示表的所有节点。节点具有[mj:catalog]混合类型。

我正在使用下一段代码查询存储:

代码语言:javascript
复制
    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进行查询:

代码语言:javascript
复制
SELECT unst.*, tbl.* FROM [nt:unstructured] AS unst 
    JOIN [mj:table] AS tbl ON ISSAMENODE(unst,tbl)
代码语言:javascript
复制
SELECT * FROM [nt:unstructured] WHERE [jcr:mixinTypes] = [mj:table]

但结果仍然是一样的。我哪里做错了?

谢谢你的帮助。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-08-30 19:33:43

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12192294

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档