MongoDB 常用的crud操作语句

目录
  • 创建数据(CREATE)
  • 更新数据(Update)
  • 删除(DELETE)
  • 读取数据(READ)

对于后端大神(小白)来说,每天的工作就是 CRUD,再加上 Control + C 和 Control + V。作为大神(小白),怎么能不懂 CRUD 呢?MongoDB 的 CRUD 相比繁琐的 SQL 语句而言十分简便,显得更为现代化。

创建数据(CREATE)

MongoDB 提供了两种方式创建数据:

db.crud.insert({name: '码农', gender: '男'});
db.crud.save({name: ' 岛上码农', gender: '男'});

save 方法的不同之处在于如果携带有 _id属性的话,就会更新对应数据,否则就是插入新的数据。在 MongoDB 3.2以后新增了两个插入方法:insertOne和insertMany,而 insert 方法已经标记为废弃。

db.crud.insertOne({name: '码农', gender: '男'});
db.crud.insertMany([{name: '岛上码农', gender: '男'},{name: '程序媛', gender: '女'}]);

更新数据(Update)

更新时前面是查询匹配条件,后面是需要更新的数据。

# 给一个码农变性
db.crud.update({name: '码农'}, {name: '码农', gender: '女'});

update 方法默认是找到一条匹配的数据更新,而不是更新全部数据,如果需要更新多条需要在后面增加属性 multi: true。同时,需要注意文档会被新的数据全部替换。

# 给全部码农变性
db.crud.update({name: '码农'}, {name: '码农', gender: '女'}, {multi: true});

MongoDB 3.2版本后增加了 updateOne 和 updateMany 方法分别对应更新一条和多条数据。

# 恢复码农的性别
db.crud.updateOne({name: '码农'}, {$set: {name: '岛上码农', gender: '男'}});
db.crud.updateMany({name: '码农'}, {$set: {name: '岛上码农', gender: '男'}});

在新版的 MongoDB 中,要求updateOne 和 updateMany 必须是原子操作,即必须指定使用 $set来指定更新的字段,以防止误操作覆盖掉整个文档。如果不指定就会报错:the update operation document must contain atomic operators。**推荐更新使用 ****updateOne**和 **updateMany**,更安全也更明确。 如果文档需要被替换,可以使用 replaceOne:

db.crud.replaceOne({name: '岛上码农'}, {name: '程序媛', gender:'女'});

删除(DELETE)

MongoDB 3.2版本后的删除方法为 deleteOne 和 deleteMany,分布对应删除一条和多条匹配的数据。

db.crud.deleteOne({name: '程序媛'});
db.crud.deleteMany({gender: '女'});

在早期的版本中,使用的是 remove 方法,remove如果第二个参数为 true 表示只删除一条匹配的数据。。

db.crud.remove({name: '程序媛'});
db.crud.remove({gender: '女'}, true);

需要特别注意,如果使用的 remove 方法查询参数对象为空,则会删除全部数据,这就要删库跑路的节奏了。

# 慎重操作,谨防删库跑路
db.crud.remove({});

读取数据(READ)

读取数据使用的是 find 或 findOne 方法,其中 find 会返回全部结果,当然也可以使用 limit 限制返回条数。

# 查询全部数据
db.crud.find();
# 只返回2条数据
db.crud.find().limit(2);
# 查询名字为Tom 的数据
db.crud.find({name: 'Tom'});

如果需要美化返回结果,则可以使用pretty()方法。

db.crud.find().limit(2).pretty();

如果要返回某些字段,则可以在后面指定返回的字段,如果要排除 _id 则需要显示指定,其他字段不包含即可,否则会报错:Cannot do exclusion on field gender in inclusion projection。

# 只返回_id和 name 字段
db.crud.find({name: 'Tom'}, {name: 1});
# 不返回_id
db.crud.find({name: 'Tom'}, {_id: 0, name: 1});

以上就是MongoDB 常用的crud语句的详细内容,更多关于MongoDB crud语句的资料请关注我们其它相关文章!

(0)

相关推荐

  • MongoDB CRUD操作中的插入实例教程

    温习了MongoDB的插入操作,主要使用PHP语言实践. 目的 理解官方shell和PHP SDK操作的差异 以MySQL的思维理解MongoDB的shell,感觉差异还是很大的 理解有多少种插入操作,以及差异点 重点理解异常操作,如何看官方文档 mongoDB shell insertMany().insert().insertOne()三个方法大体上是差不多的,insertMany()相当于批处理,insertOne()是插入当个,这两个函数返回的对象没有明确指示,insert()相当于批处

  • mongoDB中CRUD的深入讲解

    前言 今天开始接触非关系型数据库的mongoDB,现在将自己做的笔记发出来,供大家参考,也便于自己以后忘记了可以查看. 首先,mongoDB,是一种数据库,但是又区别与mysql,sqlserver.orcle等关系数据库,在优势上面也略高一筹:至于为什么会这么说呢?很简单,我们来举两个例子: 1.在存储上面,非关系型数据库可以更大规模的存储,打个比方,Facebook用的数据库就是非关系型数据库. 2.运用起来更加流畅也是这个数据库的优点,将分布式的特点发挥到极致. 当我查看官方文档的时候,简

  • MongoDB的基本操作实例详解【服务端启动,客户端连接,CRUD操作】

    本文实例讲述了MongoDB的基本操作.分享给大家供大家参考,具体如下: 本文内容: MongoDB的介绍 MongoDB服务端的启动 MongoDB客户端连接 SQL与MongoDB相关概念解释 什么是BSON 数据库操作 集合操作 文档操作 测试环境:win10 软件版本:3.6.2 首发时间:2018-03-18 15:38 MongoDB的介绍: MongoDB 是由C++语言编写的开源数据库系统. MongoDB 将数据存储为一个文档.MongoDB是一个基于分布式文件存储的数据库.

  • Springboot整合MongoDB进行CRUD操作的两种方式(实例代码详解)

    1 简介 Springboot是最简单的使用Spring的方式,而MongoDB是最流行的NoSQL数据库.两者在分布式.微服务架构中使用率极高,本文将用实例介绍如何在Springboot中整合MongoDB的两种方法:MongoRepository和MongoTemplate. 代码结构如下: 2 项目准备 2.1 启动MongoDB实例 为了方便,使用Docker来启动MongoDB,详细指导文档请参考:基于Docker的MongoDB实现授权访问的方法,这里不再赘述. 2.2 引入相关依赖

  • MongoDB 常用的crud操作语句

    目录 创建数据(CREATE) 更新数据(Update) 删除(DELETE) 读取数据(READ) 对于后端大神(小白)来说,每天的工作就是 CRUD,再加上 Control + C 和 Control + V.作为大神(小白),怎么能不懂 CRUD 呢?MongoDB 的 CRUD 相比繁琐的 SQL 语句而言十分简便,显得更为现代化. 创建数据(CREATE) MongoDB 提供了两种方式创建数据: db.crud.insert({name: '码农', gender: '男'}); d

  • mysql常用命令行操作语句

    第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql 语法如下: mysql -u用户名 -p用户密码 键入命令mysql -uroot -p, 回车后提示你输入密码,输入12345,然后回车即可进入到mysql中了,mysql的提示符是: mysql> 注意,如果是连接到另外的机器上,则需要加入一个参数-h机器IP 第三招.增加新用户 格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by

  • MongoDB与MySQL常用操作语句对照

    一.MongoDB对MySQL常用的SQL语句对应的实现 复制代码 代码如下: -------------- MySQL: SELECT * FROM user Mongo: db.user.find() -------------- MySQl: SELECT * FROM user WHERE name = 'foobar' Mongo: db.user.find({ 'name' : 'foobar' }) -------------- MySql: INSERT INTO user ('

  • Java如何操作MongoDB常用API文档

    目录 Java操作MongoDB常用API文档 1.查询指定字段 2.按条件查询 3.对查询结果排序 4.获取满足条件的前n条数据 Java使用MongoDB数据库相关API小记 MongDB数据库使用 首先介绍我的使用环境 Java操作MongoDB常用API文档 1.查询指定字段 collection.find().projection(fields(include("username","pwd"),excludeId()));//返回username与pwd

  • mysql数据库操作_高手进阶常用的sql命令语句大全 原创

    mysql数据库操作sql命令语句大全:三表连表查询.更新时批量替换字段部分字符.判断某一张表是否存在.自动增长恢复从1开始.查询重复记录.更新时字段值等于原值加上一个字符串.更新某字段为随机值.复制表数据到另一个表.创建表时拷贝其他表的数据和结构.查看当前查询缓存相关参数状态.清理查询缓存内存碎片.导出数据到pc指定目录... 1.三表连表查询 select a.aid,a.title,b.url,c.content from dq_article_content c inner join c

  • 在Java的MyBatis框架中建立接口进行CRUD操作的方法

    以接口操作的方式编程 一般来讲,我们建立映射SQL接口的类时通常会这样: public static void testBasicQuery(int id) { SqlSession session = MybatisUtils.getSqlSession(); try { /* * 此处的david.mybatis.demo.IVisitorOperation.basicQuery必须和下图中配置里面的namespace对应 */ Visitor visitor = (Visitor) ses

  • 使用go在mangodb中进行CRUD操作

    我在学习go语言之前,在对数据库进行CRUD的操作基本是用java和sql来对mysql数据库进行操作,但是到了实习中公司业务都是用的是mangodb,通过一段学习时间后,我有了一些收获. 简述关系型数据库,非关系型数据库 关系型数据库:指采用了关系模型来组织数据的数据库. 关系模型指的就是二维表格模型,而一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织 非关系型数据库 非关系型数据库:指非关系型的,分布式的,且一般不保证遵循 ACID 原则的数据存储系统. 这是比较规范的说法,具

  • springboot整合mongodb并实现crud步骤详解

    整合 首先我们得使用springboot整合咱们的mongodb,第一步,当然是引入依赖啦 <!--mybatis--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.2</version> </depende

随机推荐