如何使用Java中的QueryDSL,Spring-Data,MongoDB创建嵌入式谓词

时间:2018-03-26 15:37:22

标签: java mongodb spring-data querydsl

我的存储库实现了以下接口:

QueryDslPredicateExecutor<Rule>

mongo的文档(Rule对象)的结构是:

{
        "_id" : ObjectId("5aa924242a73bec4ce581717"),
        "name" : "test-name",
        "expressionGroups" : [
                {
                        "type" : "WHEN",
                        "expressions" : [
                                {
                                        "name" : "name1",
                                        "values" : ["VAL1", "VAL2", "VAL3"]
                                },
                                {
                                        "name" : "name2",
                                        "values" : ["VAL4", "VAL5"]
                                }
                        ]
                },
                {
                        "type" : "FOR",
                        "expressions" : [
                                {
                                        "name" : "name3",
                                        "values" : ["VAL6", "VAL7"]
                                }
                        ]
                }
        ]
}

我想使用以下方法在mongodb中找到特定的规则:

Iterable<T> findAll(Predicate predicate);

我已准备好mongo shell查询:

db.rule.find({
  'expressionGroups.expressions': {
    $all: [
      {
        '$elemMatch': {
          'name': "name1",
          'values': "VAL2"
        }
      },
      {
        '$elemMatch': {
          'name': "name3",
          'values': "VAL7"
        }
      }
    ]
  }
}).pretty()

如何根据以上查询创建com.querydsl.core.types.Predicate?

1 个答案:

答案 0 :(得分:0)

仍然没有答案,我也遇到了同样的问题。所以我创建了这样的代码:

private List<Predicate> toPredicates(String root, Map<String, Object> map) {
    List<Predicate> predicates = new ArrayList<>();

    for (Map.Entry<String, Object> entry: map.entrySet()) {
        String path = root+'.'+entry.getKey();
        Object value = entry.getValue();

        if (entry.getValue() instanceof Map) {
            predicates.addAll(toPredicates(path, (Map<String, Object>) value));
        } else {
            predicates.add(new SimplePath(path).eq(value.toString()));
        }
    }

    return predicates;
}

private static class SimplePath extends StringPath {
    protected SimplePath(String var) {
        super(var);
    }
}

因此,您可以将Json解析为Map,就是这样。