首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >OpenCMIS搜索所有文档

OpenCMIS搜索所有文档
EN

Stack Overflow用户
提问于 2022-04-26 13:55:56
回答 1查看 47关注 0票数 1

我正试图通过Alfresco通过findAllByName实现OpenCMIS功能。基本上,它应该找到所有具有特定名称的文档。

目前,我尝试进行递归搜索,但不幸的是,成本很高。

代码语言:javascript
复制
private List<Document> traverseAndFind(String name, Folder currentFolder, List<Document> foundDocuments) {

    List<Folder> subFolders = new ArrayList<>();
    for (CmisObject obj : currentFolder.getChildren()) {
        if (obj.getName().equals(name) && obj instanceof Document) {
            foundDocuments.add((Document) obj);
        } else if (obj instanceof Folder) {
            subFolders.add((Folder) obj);
        }
    }

    for (Folder subFolder : subFolders) {
        traverseAndFind(name, subFolder, foundDocuments);
    }

    return foundDocuments;
} 

从我在Folder::getChildren()实现中看到的情况来看,它一直在使用Session并发出单独的请求来查找某个文件夹的子文件夹,这导致了很长的一段时间来进行相当浅的搜索,这可能意味着我正在错误地处理问题。

有没有更好的方法来解决这个问题?例如,您将如何进行搜索,从而得到存储的绝对每个文件名的列表?

谢谢你的建议!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-04-27 08:14:06

在Alfresco中搜索的最佳方法是使用查询。

您的查询应该如下所示:

代码语言:javascript
复制
SELECT * FROM cmis:document where cmis:name = 'DOCUMENT_NAME' AND  IN_TREE('ID_FOLDER')

IN_TREE用于从特定文件夹递归搜索,如果要在所有存储库中搜索,请不要添加IN_TREE

这里是JAVA中的示例:

代码语言:javascript
复制
private List<Document> getDocumentsByName(String name, Folder folder) {

    List<Document> documents = new ArrayList<>();

    String query = "SELECT * FROM cmis:document where cmis:name = '"+name+"' AND IN_TREE('" + folder.getId() +"'";
    ItemIterable<QueryResult> results = session.query( query, false);

    //process result
    for (QueryResult qResult : results) {
        String objectId = qResult.getPropertyValueByQueryName(objectIdQueryName);
        Document doc = (Document) session.getObject(session.createObjectId(objectId));
        documents.add(doc);
    }

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

https://stackoverflow.com/questions/72015227

复制
相关文章

相似问题

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