我想对用户已在UI中选择的MongoDB中的文档列表进行批量删除操作,因此我需要动态构建一个如下所示的查询(or子句针对所选的每个文档展开):

{
    $and: [
        {
            "contentType": "application/vnd.sometype"
        },
        {
            $or: [
                {
                    "metadata.name": "someName",
                    "metadata.version": "someVersion"
                },
                {
                    "metadata.name": "someOtherName",
                    "metadata.version": "someOtherVersion"
                }
            ]
        }
    ]
},
Fields: null,
Sort: null

刚才我正在使用字符串连接来实现这一点。

是否可以使用Spring Data MongoDB Criteria Builder(org.springframework.data.mongodb.core.query.Criteria)构建此查询?

最佳答案

这不适合您吗?

Criteria criteria = Criteria.where("contentType").is("application/vnd.sometype");

List<Criteria> docCriterias = new ArrayList<Criteria>(docs.size());

for (Document doc: docs) {
    docCriterias.add(Criteria.where("metadata.name").is(doc.getName())
                               .and("metadata.version").is(doc.getVersion()));
}

criteria = criteria.orOperator(docCriterias.toArray(new Criteria[docs.size()]));

关于spring - 使用Spring Data MongoDB条件构建动态查询,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/24562481/

10-09 20:19
查看更多