ArrayList<String> labels = (ArrayList) payload.get("labels");
Aggregation aggregation = newAggregation(
match(Criteria.where("user_id").is(id).and("page_id").is(pageId).and("labels").in(labels)),
sort(Sort.Direction.DESC, "meta_data.user_data.time"),
group(Fields.fields().and("first_name", "$meta_data.user_data.first_name").and("last_name", "$meta_data.user_data.last_name").and("profile_pic", "$meta_data.user_data.profile_pic").and("user_id", "$user_id").and("labels", "$labels").and("access_times","$meta_data.access_times"))
);
AggregationResults<UsersMongoResult> groupResults = mongoTemplate.aggregate(aggregation, "chatuser_log", UsersMongoResult.class);
文档标签数组中的类似于labels: ["123", "456"]
当ArrayList labels = [“123”]结果匹配时 但是当ArrayList labels = [“123”,“789”]时,它也匹配该文档。
如何克服这个问题?
答案 0 :(得分:2)
来自in-operator的文档:
如果该字段包含一个数组,则$ in运算符选择其字段包含一个数组的文档,该数组至少包含一个与指定数组中的值匹配的元素(例如,等等)
如果要匹配包含所有指定值的数组,则需要all-operator
where("user_id").is(id).and("page_id").is(pageId).and("labels").all(labels))