服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - MongoDB - 把MongoDB作为循环队列的方法详解

把MongoDB作为循环队列的方法详解

2021-05-04 18:28kingname MongoDB

这篇文章主要给大家介绍了关于把MongoDB作为循环队列的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

我们在使用mongodb的时候,一个集合里面能放多少数据,一般取决于硬盘大小,只要硬盘足够大,那么我们可以无休止地往里面添加数据。

然后,有些时候,我只想把mongodb作为一个循环队列来使用,期望它有这样一个行为:

  1. 设定队列的长度为10
  2. 插入第1条数据,它被放在第1个位置
  3. 插入第2条数据,它被放在第2个位置
  4. ...
  5. 插入第10条数据,它被放在第10个位置
  6. 插入第11条数据,它被放在第1个位置,覆盖原来的内容
  7. 插入第12条数据,它被放在第2个位置,覆盖原来的内容
  8. ...

mongodb有一种collection叫做capped collection,就是为了实现这个目的而设计的。

普通的collection不需要提前创建,只要往mongodb里面插入数据,mongodb自动就会创建。而capped collection需要提前定义一个集合为capped类型。

语法如下:

?
1
2
3
4
5
6
import pymongo
 
conn = pymongo.mongoclient()
db = conn.test_capped
 
db.create_collection('info', capped=true, size=1024 * 1024 * 10, max=5)

对一个数据库对象使用create_collection方法,创建集合,其中参数capped=true说明这是一个capped collection,并限定它的大小为10mb,这里的size参数的单位是byte,所以10mb就是1024 * 1024 * 10. max=5表示这个集合最多只有5条数据,一旦超过5条,就会从头开始覆盖。

创建好以后,capped collection的插入操作和查询操作就和普通的集合完全一样了:

?
1
2
3
4
col = db.info
for i in range(5):
  data = {'index': i, 'name': 'test'}
  col.insert_one(data)

这里我插入了5条数据,效果如下图所示:

把MongoDB作为循环队列的方法详解

其中,index为0的这一条是最先插入的。

接下来,我再插入一条数据:

?
1
2
data = {'index': 100, 'name': 'xxx'}
col.insert_one(data)

此时数据库如下图所示:

把MongoDB作为循环队列的方法详解

可以看到,index为0的数据已经被最新的数据覆盖了。

我们再插入一条数据看看:

?
1
2
data = {'index': 999, 'name': 'xxx'}
col.insert_one(data)

运行效果如下图所示:

把MongoDB作为循环队列的方法详解

可以看到,index为1的数据也被覆盖了。

这样我们就实现了一个循环队列。

mongodb对capped collection有特别的优化,所以它的读写速度比普通的集合快。

但是capped collection也有一些缺点,在mongodb的官方文档中提到:

if an update or a replacement operation changes the document size, the operation will fail.

you cannot delete documents from a capped collection. to remove all documents from a collection, use the drop() method to drop the collection and recreate the capped collection.

意思就是说,capped collection里面的每一条记录,可以更新,但是更新不能改变记录的大小,否则更新就会失败。

不能单独删除capped collection中任何一条记录,只能整体删除整个集合然后重建。

总结

到此这篇关于把mongodb作为循环队列的文章就介绍到这了,更多相关mongodb作循环队列内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://mp.weixin.qq.com/s/K9ycjgBE_fMHTk043y40ZA

延伸 · 阅读

精彩推荐
  • MongoDBMongoDB系列教程(五):mongo语法和mysql语法对比学习

    MongoDB系列教程(五):mongo语法和mysql语法对比学习

    这篇文章主要介绍了MongoDB系列教程(五):mongo语法和mysql语法对比学习,本文对熟悉Mysql数据库的同学来说帮助很大,用对比的方式可以快速学习到MongoDB的命...

    MongoDB教程网3252020-05-01
  • MongoDBWindows下MongoDB配置用户权限实例

    Windows下MongoDB配置用户权限实例

    这篇文章主要介绍了Windows下MongoDB配置用户权限实例,本文实现需要输入用户名、密码才可以访问MongoDB数据库,需要的朋友可以参考下 ...

    MongoDB教程网3082020-04-29
  • MongoDBMongoDB查询之高级操作详解(多条件查询、正则匹配查询等)

    MongoDB查询之高级操作详解(多条件查询、正则匹配查询等)

    这篇文章主要给大家介绍了关于MongoDB查询之高级操作(多条件查询、正则匹配查询等)的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者...

    w田翔3872020-12-19
  • MongoDBmongodb数据库基础知识之连表查询

    mongodb数据库基础知识之连表查询

    这篇文章主要给大家介绍了关于mongodb数据库基础知识之连表查询的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mongodb具有一定的参...

    ZJW02155642020-05-22
  • MongoDB在mac系统下安装与配置mongoDB数据库

    在mac系统下安装与配置mongoDB数据库

    这篇文章主要介绍了在mac系统下安装与配置mongoDB数据库的操作步骤,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪...

    CXYhh1219312021-11-14
  • MongoDBMongoDB多条件模糊查询示例代码

    MongoDB多条件模糊查询示例代码

    这篇文章主要给大家介绍了关于MongoDB多条件模糊查询的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值...

    浅夏晴空5902020-05-25
  • MongoDBMongoDB的索引

    MongoDB的索引

    数据库中的索引就是用来提高查询操作的性能,但是会影响插入、更新和删除的效率,因为数据库不仅要执行这些操作,还要负责索引的更新 ...

    MongoDB教程网2532020-05-12
  • MongoDBMongodb索引的优化

    Mongodb索引的优化

    MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。接下来通过本文给大家介绍Mongodb索引的优化,本文介绍的非常详细,具有参考借鉴价值,感...

    MRR3252020-05-05