FieldPath字段名称可能不包含“。”

时间:2017-04-29 10:34:30

标签: spring mongodb

对于mongodb 3.2以下查询成功运作。

db.user_log.aggregate([{ "$match" : { "user_id" : "1" , "page_id" : "678761252281073"}} , { "$sort" : { "meta_data.access_times" : -1}} , { "$group" : { "_id" : { "first_name" : "$meta_data.user_data.first_name" , "last_name" : "$meta_data.user_data.last_name" , "profile_pic" : "$meta_data.user_data.profile_pic" , "user_id" : "$user_id" , "star_value" : "$star_value" , "access.times" : "$meta_data.access_times"}}}])

Java代码 -

Aggregation aggregation =  newAggregation(
            match(Criteria.where("user_id").is("123")),
            sort(Sort.Direction.DESC, "meta_data.access_times"),
            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("star_value", "$star_value").and("access.times", "$meta_data.access_times"))
        );
AggregationResults<UsersMongoResult> groupResults = mongoTemplate.aggregate(aggregation, "user_log", UsersMongoResult.class);

但在升级到3.4之后,它发生在异常

之后
  

org.springframework.dao.InvalidDataAccessApiUsageException:命令   执行失败:错误[FieldPath字段名称可能不包含'。'。]

这背后的原因是什么,我该如何解决这个问题 ?

1 个答案:

答案 0 :(得分:1)

问题是access.times,在您的字段中使用.是一种不好的做法,因为它会与嵌套元素发生冲突。