如何使用MongoDB聚合框架获取最后一个子字符串?

问题描述 投票:0回答:1

假设我有这些文件

> db.coll.find().toArray()
[
    {
        "_id" : ObjectId("5a36c3e218948d0722457078"),
        "locality" : "Nasimi, Baku, Azerbaijan"
    },
    {
        "_id" : ObjectId("5a36c3e218948d0722457079"),
        "locality" : "Garland, TX, USA"
    },
    {
        "_id" : ObjectId("5a36c3e218948d072245707a"),
        "locality" : "Halytskyi District, Lviv, Lviv Oblast, Ukraine"
    },
    {
        "_id" : ObjectId("5a36c3e218948d072245707b"),
        "locality" : "Tozeur, Tunisia"
    }
]

我想只得到这个国家,即最后一个逗号之后的任何东西(', ')。

EG

[
    "Azerbaijan",
    "USA",
    "Ukraine",
    "Tunisia"
]

我已经设法获得第一个逗号的索引以及之后的内容但我无法弄清楚如何获得最后一个逗号。

db.coll
  .aggregate([
    {
      $project: {
        lastIndexOf: { $indexOfBytes: [ '$locality', ', ' ] },
        locality: '$locality',
      }
    },
    {
      $project: {
        lastIndexOfPlusTwo: { $add: [ '$lastIndexOf', 2 ] },
        locality: '$locality',
      }
    },
    {
      $project: { country: { $substr: [ '$locality', '$lastIndexOfPlusTwo', -1 ] } }
    }
  ]).pretty()

{
    "_id" : ObjectId("5a36c3e218948d0722457078"),
    "country" : "Baku, Azerbaijan"
}
{
    "_id" : ObjectId("5a36c3e218948d0722457079"),
    "country" : "TX, USA"
}
{
    "_id" : ObjectId("5a36c3e218948d072245707a"),
    "country" : "Lviv, Lviv Oblast, Ukraine"
}
{
    "_id" : ObjectId("5a36c3e218948d072245707b"),
    "country" : "Tunisia"
}

这可以工作,但是它会将所有结果加载到JavaScript Mongo Shell的内存中,但如果可以使用单个MongoDB聚合命令完成它,那将是理想的。

var res2 = db.coll.aggregate();

res2 = res2.toArray().map(function(doc) {
  var lastIndex = doc.locality.lastIndexOf(',');
  return doc.locality.slice(lastIndex + 2);
});

[ "Azerbaijan", "USA", "Ukraine", "Tunisia" ]

也许与$let$split

mongodb aggregation-framework
1个回答
1
投票

您可以尝试以下聚合查询。

{"$arrayElemAt":["$$locality",-1]}访问数组中的最后一个元素。

db.coll.aggregate([{"$project":{
  "_id":0,
  "last":{
    "$let":{
      "vars":{"locality":{"$split":["$locality",","]}},
      "in":{"$arrayElemAt":["$$locality",-1]}
    }
  }
}}])
© www.soinside.com 2019 - 2024. All rights reserved.