MongoDB CRUD 概述

当本地安装完mongodb数据库后,或拿到一个新的数据库连接字符串时。对于新手来说, 避免不了手痒难耐,想对数据库大肆折腾一番。看到数据库当中存在自己定制化的数据后,心中的成就感油然而生。 本文介绍mongodb简单的crud操作,为广大mongodb入门用户止痒。

CRUD

CRUD操作,就是create, read, update,delete操作,即mongodb数据库文档的增删改查

create增加文档数据

mongodb的创建操作,就是向集合中添加或插入文档。如果集合和所在的数据库不存在,mongodb在插入数据前,会自动创建和添加集合和数据库。

mongodb提供了两种方法插入数据

复制代码
//插入一条数据
db.collection.insertOne()
//插入多条数据
db.collection.insertMany()

mongodb中,插入操作是针对一个文档的操作。insertMany()方法在执行时,会转化成insertOne()方法逐一插入文档。insertOne()方法是原子操作,而insertMany()方法,是非原子操作。

向集合中插入一条数据

复制代码
db.users.insertOne( //指定向user集合插入数据    
	{ //定义一份bson格式的文档        
    name: "sue",  //字段:值        
    age: 26, /字段:值        
    status: "pending" /字段:值     
  }
)

read读取文档数据

读取操作,就是从指定集合中获取数据。

在mongodb中,使用最简单的find方法,集合查询出数据

复制代码
db.collection.find()

用户可以指定查询条件,对执行find()所产生的游标进行限定

复制代码
db.users.find( //指定在集合users中查找
	{ age: { $gt: 18}}, //设置过滤条件    
  { name: 1, address: 1} //返回name和address字段
).limit(5) //限制返回前面5条数据,按照插入时间排序

update更新文档数据

更新操作,就是修改集合中已经存在的文档。

mongodb提供三种方式修改集合中的文档

复制代码
//修改一条文档
db.collection.updateOne()
//修改一条或多条文档记录
db.collection.updateMany()
//替换一个文档记录
db.collection.replaceOne()

在mongodb中,更新操作是针对一份文档的操作。updateMany()方法在mongodb执行过程中,也会转化成对文档的逐一更新操作。更新一份文档的操作是原子性的。而updateMany()方法,不是原子性的。

用户可以指定查询条件或过滤器,需要修改的字段和目标值,即可完成更新操作

复制代码
db.users.updateMany( //指定更新集合    
	{ age: {$lt: 18}},//设置过滤条件    
	{$set: { status: "rejecct"}//更新status字段
)

delete删除文档数据

删除操作,是从指定集合中删掉部分文档或全部文档。

mongodb提供了两种方式删除文档

复制代码
//删除一条文档记录
db.collection.deleteOne()
//删除一条或多条文档记录
db.collection.deleteMany()

在mongodb中,删除操作,是针对一份文档的操作。deleteMany()方法在mongodb执行过程中,也会转化成deleteOne()操作。mongodb对单文档的操作是原子的。deleteOne()操作是原子操作;而deleteMany()不是原子操作。

在deleteOne()和deleteMany()方法中,用户可以指定过滤器。语法与查询语句过滤器相同

复制代码
db.users.deleteMany( //指定集合users
	{ status: "reject"}  //设置过滤条件
)
相关推荐
稚辉君.MCA_P8_Java24 分钟前
WebSocket 是什么原理?为什么可以实现持久连接?
网络·数据库·websocket·网络协议
小光学长42 分钟前
基于Vue的图书馆座位预约系统6emrqhc8(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
code小毛孩1 小时前
如何简单的并且又能大幅度降低任务队列的锁粒度、提高吞吐量?
java·jvm·数据库
风随心飞飞2 小时前
linux 环境下mysql 数据库自动备份和清库 通过crontab 创建定时任务实现mysql数据库备份
linux·数据库·mysql
奥尔特星云大使2 小时前
读写分离中间件简介
数据库·mysql·中间件·读写分离
友莘居士2 小时前
高效处理 Excel 海量数据入库:编程脚本、CSV 中间件、图形工具优化全攻略
数据库·中间件·excel·csv·海量数据·入库
Han.miracle3 小时前
数据库圣经第二章——简单的my.ini基础配置介绍
数据库
八怪4 小时前
KILL MTS的一个worker线程会怎么样
数据库
-Xie-5 小时前
Mysql杂志(三十一)——Join连接算法与子查询、排序优化
数据库·mysql
程序新视界5 小时前
在连表查询场景下,MySQL隐式转换存在的坑
数据库·mysql·dba