OpenCMIS 搜索所有文档
OpenCMIS searching for all Documents
我正在尝试通过 OpenCMIS 在 Alfresco DMS 上执行 findAllByName 功能。基本上它应该找到具有特定名称的所有文档。
目前我尝试进行递归搜索,不幸的是非常昂贵。
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
一起工作,并发出单独的请求来查找某个文件夹的子文件夹,导致整体时间很长一个相当浅的搜索,这可能意味着我正在错误地处理问题。
有更好的方法吗?例如,您将如何进行搜索,从而得到一个包含所有存储文件名的列表?
感谢任何提示!
在 Alfresco 中搜索的最佳方式是使用查询
您的查询应该是这样的:
SELECT * FROM cmis:document where cmis:name = 'DOCUMENT_NAME' AND IN_TREE('ID_FOLDER')
IN_TREE
用于从特定文件夹递归搜索,如果要在所有存储库中搜索,请不要添加 IN_TREE
这里是 JAVA 中的示例:
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;
}
我正在尝试通过 OpenCMIS 在 Alfresco DMS 上执行 findAllByName 功能。基本上它应该找到具有特定名称的所有文档。
目前我尝试进行递归搜索,不幸的是非常昂贵。
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
一起工作,并发出单独的请求来查找某个文件夹的子文件夹,导致整体时间很长一个相当浅的搜索,这可能意味着我正在错误地处理问题。
有更好的方法吗?例如,您将如何进行搜索,从而得到一个包含所有存储文件名的列表?
感谢任何提示!
在 Alfresco 中搜索的最佳方式是使用查询
您的查询应该是这样的:
SELECT * FROM cmis:document where cmis:name = 'DOCUMENT_NAME' AND IN_TREE('ID_FOLDER')
IN_TREE
用于从特定文件夹递归搜索,如果要在所有存储库中搜索,请不要添加 IN_TREE
这里是 JAVA 中的示例:
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;
}