如何使用springmongodb操作$concat



我正在使用spring数据mongodb(版本为1.8.1.release)来操作我的mongodb,但是我遇到了一个问题。我想使用聚合来投影一个新的字段,它使用#concat来连接两个字段。像这样:

{
"$project":{
    "idai" : {
        "$concat": [
        {"$substr":["$channel_id",0,-1]},
        "-",
        {"$substr":["$no_ai",0,-1]}
        ]
    },
    ...
}

下面的代码是我的java代码

AggregationResults<QualifyHourData> results = mongoOps.aggregate(newAggregation(HisAiInfo.class, 
            match(where("date").gte(startTime.toDate()).lt(endTime.toDate())),
            project("date","zset").andExpression("$channelId + [0] + $noAi",CHAR_CHANNELID_NOAI).as("idai"),
            ...
            ), QualifyHourData.class);

运行时,日志为:

{ 
  "aggregate" : "last" , 
  "pipeline" : [ 
    { "$match" : { "date" : { "$gte" : { "$date" : "2015-11-30T16:00:00.000Z"} , "$lt" : { "$date" : "2015-12-31T16:00:00.000Z"}}}},
    { "$project" : { "date" : 1 , "zset" : 1 , "idai" : { "$add" : [ "$channel_id" , "_" , "$no_ai"]}}} , ...
  ]
}

看,这不是我过期的。请帮忙!!!

刚刚总结了解决方案,以帮助其他有同样问题的人。

您可以使用org.springframework.data.mongodb.core.aggregation.ProjectionOperation类中的"andExpression"函数连接这些值。

示例:-

ProjectionOperation project = Aggregation.project("year", "initial").andExpression("concat(year,'-', initial)").as("yearAndInitial");

从Spring Data MongoDB 2.0开始,您可以使用StringUtils.Concat:

project("_id",)
    .and("firstName")
    .concat(" ", fields("lastName"))
    .as("fullName"),

最新更新