迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 数据库 > MongoDB >

获取 MongoDB 中的最后 N 条记录

作者:迹忆客 最近更新:2023/03/17 浏览次数:

本文将探讨获取 MongoDB 中最后 N 条记录的方法数量,其中 N 为正数且大于零。我们将看到如何检索有无排序的文档数量。

获取 MongoDB 中的最后 N 条记录

我们必须有一个包含文档的集合才能继续实际示例。因此,让我们继续使用以下查询来创建一个集合并在其中插入一些文档。

示例代码:

> use get_n_records;
> db.createCollection('stock');
> db.stock.insertMany([
    {"item": "abc", "quantity": 12},
    {"item": "def", "quantity": 234},
    {"item": "ghi", "quantity": 45},
    {"item": "jkl", "quantity": 345},
    {"item": "mno", "quantity": 243},
    {"item": "pqr", "quantity": 345},
    {"item": "stu", "quantity": 56},
    {"item": "vwx", "quantity": 575},
    {"item": "yzz", "quantity": 398}
]);
> db.stock.find();

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e75fb"), "item" : "abc", "quantity" : 12 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fc"), "item" : "def", "quantity" : 234 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fd"), "item" : "ghi", "quantity" : 45 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fe"), "item" : "jkl", "quantity" : 345 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75ff"), "item" : "mno", "quantity" : 243 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7600"), "item" : "pqr", "quantity" : 345 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7601"), "item" : "stu", "quantity" : 56 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7602"), "item" : "vwx", "quantity" : 575 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7603"), "item" : "yzz", "quantity" : 398 }

现在,我们已经准备好并填充了我们的集合。关键是要考虑我们是否要从最近插入的文档到最近插入的文档中获取最后 N 条记录,反之亦然。

让我们学习下面给出的每个场景。

从最近插入的文档到最近插入的文档中获取最后 N 条记录,反之亦然

在继续之前,请查看以下两个术语以轻松理解它们:

使用 cursor.sort() 方法从最近插入的文档到最近插入的文档中获取最后 N 条记录,反之亦然

示例代码(后进先出):

> db.stock.find().sort({_id:-1}).limit(3);

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e7603"), "item" : "yzz", "quantity" : 398 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7602"), "item" : "vwx", "quantity" : 575 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7601"), "item" : "stu", "quantity" : 56 }

示例代码(先进先出):

> db.stock.find().sort({_id:1}).limit(3);

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e75fb"), "item" : "abc", "quantity" : 12 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fc"), "item" : "def", "quantity" : 234 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fd"), "item" : "ghi", "quantity" : 45 }

在这里,我们使用 sort() 方法将文档从最近到最近的插入顺序(降序)排序。因此,在从数据库中获取任何文档(记录)之前,我们将 sort() 方法应用于游标。

sort() 方法的字段值对为 {field: value},我们最多可以对 32 个键执行排序。使用 MongoDB 时,文档未按指定顺序存储在集合中。

这就是为什么当我们对具有重复值的特定字段执行排序时,具有这些值的文档可能会以任何顺序返回。为了获得一致的排序,我们必须至少包含一个包含唯一值的字段。

确保这一点的最简单方法是在 sort() 方法中使用 _id 字段。

limit(N) 用于获取指定数量的文档。如果我们有兴趣获取所有排序的文档,我们可以省略这个函数。

或者,我们也可以在没有特定字段的情况下使用如下查询。

示例代码:

> db.stock.find().sort({$natural:1}).limit(3);

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e75fb"), "item" : "abc", "quantity" : 12 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fc"), "item" : "def", "quantity" : 234 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fd"), "item" : "ghi", "quantity" : 45 }

如果 $natural 的值分别为 1-1,则它们的工作方式类似于先进先出和后进先出。如果我们有 MongoDB 4.4 或更高版本,我们可以使用它。

使用 $sort$limit (聚合) 阶段从最近插入的文档到最近插入的文档中获取最后 N 条记录,反之亦然

示例代码(后进先出):

> db.stock.aggregate([
     { $sort : { _id : -1 } },
     { $limit : 4 }
]);

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e7603"), "item" : "yzz", "quantity" : 398 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7602"), "item" : "vwx", "quantity" : 575 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7601"), "item" : "stu", "quantity" : 56 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7600"), "item" : "pqr", "quantity" : 345 }

示例代码(先进先出):

> db.stock.aggregate([
     { $sort : { _id : 1 } },
     { $limit : 4 }
]);

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e75fb"), "item" : "abc", "quantity" : 12 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fc"), "item" : "def", "quantity" : 234 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fd"), "item" : "ghi", "quantity" : 45 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fe"), "item" : "jkl", "quantity" : 345 }

$sort 聚合阶段类似于 cursor.sort() 方法。它用于对所有文档进行排序,并将它们按排序顺序返回到管道。

它需要一个具有字段名称和相应排序顺序的文档。请记住,1-1 用于升序和降序。

cursor.sort() 方法一样,我们可以使用 $sort 聚合阶段对最多 32 个键进行排序,并具有至少一个字段(包含唯一值)以实现一致的排序顺序。

如果我们需要对多个字段进行排序,排序顺序是从左到右评估的。而 $limit 采用一个数字,显示需要在屏幕上打印多少个文档;此外,它具有 64 位整数限制。

结合使用 skip()count() 方法获取 MongoDB 中的最后 N 条记录

这种方法很吸引人,因为考虑到项目要求,我们不是对数据进行排序,而是从头或尾获取一段文档。

示例代码(获取前 3 条记录而不对文档进行排序):

> db.stock.find().limit(3);

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e75fb"), "item" : "abc", "quantity" : 12 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fc"), "item" : "def", "quantity" : 234 }
{ "_id" : ObjectId("629ac651b7e637e64d8e75fd"), "item" : "ghi", "quantity" : 45 }

示例代码(获取最后 3 条记录而不对文档进行排序):

> db.stock.find().skip(db.stock.count() - 3)

输出:

{ "_id" : ObjectId("629ac651b7e637e64d8e7601"), "item" : "stu", "quantity" : 56 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7602"), "item" : "vwx", "quantity" : 575 }
{ "_id" : ObjectId("629ac651b7e637e64d8e7603"), "item" : "yzz", "quantity" : 398 }

在这个例子中,我们使用 db.stock.count() 来计算文档的总数,从中减去 3 并使用 skip() 方法跳过所有文档。

请记住,我们减去的文档数量没有被跳过(在本例中为 3)。我们将得到这 3 个文件。

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

比较 MongoDB 中的字段

发布时间:2023/04/21 浏览次数:51 分类:MongoDB

在本文中,我们将了解如何比较 MongoDB 中的两个字段。 此外,我们将看到一个相关的示例和解释,以使主题更容易理解。

清除或删除 MongoDB 中的集合

发布时间:2023/04/21 浏览次数:147 分类:MongoDB

本篇文章将告诉大家如何删除 MongoDB 数据库中的集合以及删除 MongoDB 中的集合的不同方法。

MongoDB 截断集合

发布时间:2023/04/21 浏览次数:178 分类:MongoDB

可以根据需要选择两个选项之一来截断下面的集合。 在今天的文章中,我们将学习如何在 MongoDB 中截断集合。

删除 MongoDB 中的重复项

发布时间:2023/04/21 浏览次数:151 分类:MongoDB

在本文中,我们将了解如何删除 MongoDB 中的重复条目,并且我们还将看到一个带有适当解释的示例,以使主题更容易理解。

使用 NodeJS 检查 MongoDB 中是否存在集合

发布时间:2023/04/21 浏览次数:194 分类:MongoDB

在本文中,我们将检查 MongoDB 数据库中是否存在一个集合,并且我们还将查看与主题相关的示例,以使主题更容易理解。 为此,我们将使用 Node.js。

MongoDB 中的唯一索引

发布时间:2023/04/21 浏览次数:144 分类:MongoDB

在这篇教学文章中,您将了解唯一索引、它们是什么以及如何在 MongoDB 中使索引唯一。 此外,还简要详细地解释了使用户的电子邮件在 MongoDB 中唯一。

在 MongoDB 中创建索引

发布时间:2023/04/21 浏览次数:104 分类:MongoDB

索引有助于有效解决查询。 如果没有索引,MongoDB 必须遍历集合中的每个文档才能找到与查询匹配的文档。因此,在今天的文章中,我们将学习如何在 MongoDB 中创建索引。

MongoDB 中的稀疏索引

发布时间:2023/04/21 浏览次数:142 分类:MongoDB

在本文中,我们将讨论 MongoDB 中的稀疏索引。 此外,我们将提供一个相关示例并进行解释,以使该主题更容易理解。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便