使用mongodb实现简单的读写操作

 更新时间:2023年12月08日 09:37:26   作者:威赞  
这篇文章主要给大家介绍了如何使用mongodb实现简单的读写操作,本文适合初学者,特别是刚刚安装了mongodb数据库的朋友,或在atlas刚拿到免费集群的朋友,文中有详细的代码示例供大家参考,需要的朋友可以参考下

引言

本文适合初学者,特别是刚刚安装了mongodb数据库的朋友,或在atlas刚拿到免费集群的朋友。

拿到数据库,心情很激动,手痒难耐。特别想向数据库插入几条数据库试试。即使是深夜完成了安装,也忍不住想去完成这些操作。看到数据库里的记录,心中会更有成就感。

这是一个里程碑的时刻,代表着mongodb学习的开始。或者其他任何一种数据库技能学习的开始。

本文基于官方文档,整理出mongodb简单的增删改查操作。

创建操作

创建操作,是向集合中添加一个新的文档。mongodb的一条记录称为一个文档。文档是类似JSON结构的BSON结构的键值对对象,支持字符串,数值,布尔类型,时间,数组,对象等类型。多条文档构成了mongodb的一个集合。

当插入文档的集合不存在时,mongodb自动创建这个集合。

Mongodb提供了两种文档插入方法

db.collection.insertOne()
db.collection.insertMany()
 
//举例
db.users.insertOne({
  name:"sue",
  age: 26,
  gentle: "Female"
})
 
db.users.insertMany([{
  name:"sue",
  age: 26,
  gentle: "Female"
},{
  name:"james",
  age: 28,
  gentle: "Male"
}])

其中集合名称是users, 文档是带有三个字段name, age, gentle的对象。

使用insertOne方法,插入一条文档,参数是一个对象。而使用insertMany方法,插入多条文档,参数是一个数组。

Mongodb对单个文档的操作是原子性的,即对于单个文档的操作,只有成功和失败两个结果。成功, 则数据保存到数据库。失败,则没有数据保存到数据库。不会出现保存了一半这样的中间状态。insertOne向数据库中插入一条文档记录,是原子操作。insertMany向数据库插入多条文档,不是原子操作。

查询操作

查询操作,是从数据库的某个集合中读取文档。

mongodb提供find()方法,实现从集合中读取文档数据。

db.collection.find()

在find()方法中,可以带有参数,作为查询参数,限定查询返回值。如对前面插入的user集合进行查询

//查询所有数据
db.users.find()
//查询name为sue的数据
db.users.find({
  name: "sue"
})
//限制返回数量
db.users.find().limit(5)

修改操作

修改操作更新数据库制定集合中符合查询条件的文档数据。mongodb提供了几种方法来支持数据的更新

//更新一条数据
db.collection.updateOne()
//更新多条数据
db.collection.updateMany()
//替换一条数据
db.collection.replaceOne()

用户在修改操作的第一个参数指定查询过滤条件,在第二个参数中指定修改字段和目标值。如修改集合users中name为james的age字段

db.users.updateOne({name: "james"},{$set: {"age": 30}})

其中过滤条件{name: "james"}用来筛选集合中符合name是james的文档。使用$set设置更新的字段和字段值。

Mongodb对单个文档的修改是原子性的,因此updateOne(), replaceOne()方法,都是原子操作。updateMany()方法操作单条记录,也是原子性的,操作多条记录时,是非原子操作。

删除操作

删除操作,是删除集合中的文档。mongodb提供了两种方法来删除文档。

//删除一条文档
db.collection.deleteOne()
//删除多条文档
db.collection.deleteMany()

删除方法的参数中指定查询过滤条件,使用该条件查询出来的结果会被删除。如删除users表中男性数据。

db.users.deleteMany({gentle: 'Male'})

删除users表中name是james的数据

db.users.deleteOne({name: 'James'})

Mongodb中对单个文档的操作是原子的。所以deleteOne是原子操作, deleteMany不是原子操作。

一点建议

数据库操作中,修改操作和删除操作,都是比较危险的操作。数据一旦修改保存到数据库,很难恢复到修改前的样子。对于单条数据,恢复起来容易。对于批量数据的修改更新,请使用查询语句反复确认修改删除范围后,再执行操作。并准备好数据恢复脚本。

以上就是使用mongodb实现简单的读写操作的详细内容,更多关于mongodb读写操作的资料请关注脚本之家其它相关文章!

相关文章

  • 详解mongodb 主从配置

    详解mongodb 主从配置

    我研究过的nosql,memcache,redis,mongodb都是支持分布式的,生产环境中用过memcache,redis,性能稳定。mongodb是最接近关系型数据库的,不用花很多时间去构建数据库模型,将来我会用mongodb,看一下主从配置
    2014-07-07
  • MongoDB批量将时间戳转为通用日期格式示例代码

    MongoDB批量将时间戳转为通用日期格式示例代码

    这篇文章主要给大家介绍了关于MongoDB批量将时间戳转为通用日期格式的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07
  • Mongodb多键索引中索引边界的混合问题小结

    Mongodb多键索引中索引边界的混合问题小结

    Mongodb为提高数组的查询效率,针对数组构建了多键索引,而Mongodb在应用多键数组查询时,也通过构建,减少数组查询的数值范围,来提高查询性能,本文结合Mongodb官方文档,阐述Mongodb在使用多键索引时的边界优化,感兴趣的朋友一起看看吧
    2024-07-07
  • MongoDB Server 用户名和密码登录的操作步骤

    MongoDB Server 用户名和密码登录的操作步骤

    MongoDB Server默认不进行安全认证,即任何MongoDB Client都可以连接并拥有操作权限,这篇文章主要介绍了MongoDB Server 用户名和密码登录的步骤,需要的朋友可以参考下
    2024-03-03
  • MongoDB 管道的介绍及操作符实例

    MongoDB 管道的介绍及操作符实例

    这篇文章主要介绍了MongoDB 管道的介绍及操作符实例的相关资料,MongoDB的聚合管道将MongoDB文档在一个管道处理完毕后将结果传递给下一个管道处理,需要的朋友可以参考下
    2017-07-07
  • 如何对 MongoDB 进行性能优化(五个简单步骤)

    如何对 MongoDB 进行性能优化(五个简单步骤)

    MongoDB一直是最流行的NoSQL,而根据DB-Engines Ranking最新的排行,时下MongoDB已经击败PostgreSQL跃居数据库总排行的第四位,仅次于Oracle、MySQL和Microsoft SQL Server。本文给大家介绍MongoDB性能优化的简单总结。
    2015-10-10
  • MongoDB快速入门笔记(七)MongoDB的用户管理操作

    MongoDB快速入门笔记(七)MongoDB的用户管理操作

    这篇文章主要介绍了MongoDB快速入门笔记(七)MongoDB的用户管理操作 的相关资料,需要的朋友可以参考下
    2016-06-06
  • MongoDB数据库性能监控详解

    MongoDB数据库性能监控详解

    MongoDB作为图片和文档的存储数据库,为啥不直接存MySQL里,还要搭个MongoDB集群,麻不麻烦?这篇文章就带你介绍MongoDB数据库性能监控,感兴趣的同学可以参考阅读
    2023-03-03
  • 详解MongoDB的条件查询和排序

    详解MongoDB的条件查询和排序

    MongoDB 提供了丰富的查询功能,包括条件组合、反向查询、查询结果过滤、排序等,借助 MongoDB 多样化的查询方式,可以完成业务上的各类查询需要。
    2021-06-06
  • MongoDB中方法limit和skip的使用

    MongoDB中方法limit和skip的使用

    这篇文章主要给大家介绍了关于MongoDB中方法limit和skip的使用方法,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03

最新评论