我正在使用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"),