Spring data Mongo db 从文档转换为标准

Spring data Mongo db Convert from Document to Criteria

所以从 Criteria 我们有 getCriteriaObject 其中 returns Document 然后你可以对文档做一些操作,但是我想使用通过转换回 Criteria 结果,我真的找不到如何。

当然,让我们考虑具有多个运算符等的复杂 Criteria。有什么想法吗?

简答:否

Criteria 具有类似于 Querydsl 的语法,允许生成 类型安全的 查询。从 Document 读取可能会引入 MongoDB 与当前 MongoDB 版本不兼容的命令或语法

长答案:是

我们可以使用 Java reflection 实施 walkaround 以将文档 key:value 添加到条件 private 字段中。
警告:您假设您的 Document 具有语法正确的兼容运算符。

将此辅助方法添加到您的 class (souce):

public static Criteria from(Document document) {
    Criteria c = new Criteria();

    try {

        Field _criteria = c.getClass().getDeclaredField("criteria");
        _criteria.setAccessible(true);

        @SuppressWarnings("unchecked")
        LinkedHashMap<String, Object> criteria = (LinkedHashMap<String, Object>) _criteria.get(c);

        for (Entry<String, Object> set : document.entrySet()) {
            criteria.put(set.getKey(), set.getValue());
        }

        Field _criteriaChain = c.getClass().getDeclaredField("criteriaChain");
        _criteriaChain.setAccessible(true);

        @SuppressWarnings("unchecked")
        List<Criteria> criteriaChain = (List<Criteria>) _criteriaChain.get(c);
        criteriaChain.add(c);

    } catch (Exception e) {
        // Ignore
    }

    return c;
}

现在从 DocumentCriteria 创建新实例:

Criteria newCriteria = from(criteria.getCriteriaObject());

//You have full-compatible Criteria instance
newCriteria.and("foobar").elemMatch(Criteria.where("field").is("value"));