缘由:使用MongoDB时遇到一些需要查询/更新操作指定某些字段的业务场景

  • 查询和更新指定字段就需要进行简单的筛选和过滤,也能在大数据量时减少查询消耗时间

1. 查询数据库某些指定字段,同时默认返回_id字段

  db.users.find({},{ username: 1})

以上查询为只查询users表中的所有数据的username字段,但每条查询到的记录默认还会返回_id

2. 查询数据库某些指定字段,并不返回_id字段

  db.users.find({},{ username: 1, _id: 0 })

以上查询为只查询并只返回users表中的所有数据的username字段,_id字段也不会返回

语法为db.[collectionName].find({查询器},{筛选器}),通过设置字段的1或0来进行筛选

3. update()方式更新数据库某些记录的某些指定字段,这里遇到了坑,慎用db.[collectionName].update()

  db.users.update({'username':'John'},{ 'age': 24})

以上更新为查找到users表中username为John的记录并更新其age字段值为24;

特别注意:使用update更新会把users表中username为John的记录,除_id的其他字段全部清空,只会保留_id字段和刚刚更新的age字段,所以需要慎用;

因为update这种文档更新方式,会用新的记录直接代替旧记录,所以需要慎用。

语法为db.[collectionName].update({查询器},{修改器})

4. $set方式更新数据库某些记录的某些指定字段

  db.users.update({'username':'John'},{$set:{'age': 24}})

以上更新为查找到users表中username为John的记录并更新其age字段值为24;

$set修改器用来指定一个键值对,如果存在键就进行修改不存在则进行添加。

5. insertOrUpdate更新方式(查询器查出来数据就执行更新操作,查不出来就替换操作)

  db.[collectionName].update({查询器},{修改器},true)

语法:第三个参数设置为true,代表insertOrUpdate,即存在即更新,否则插入该数据。

6. 批量更新方式(因为默认情况下,当查询器查询出多条符合条件的数据时,默认修改第一条数据,不能批量更新)

  db.[collectionName].update({查询器},{修改器},false, true)

语法:添加第四个参数,该参数为true,则批量更新,为false,则更新一条。

7. $inc数字类型修改器

  db.users.update({'username':'John'},{$inc:{'age': 1}})

以上更新为查找到users表中username为John的记录并在其age字段值在原来的数值上进行加一后更新,字段后设置为 -1 则为在原来的数值上减一后更新;

$inc修改器仅用于数字类型字段,他可以为指定的键对应的数字类型的数值进行加减操作。

MongoDB数据库,一些的筛选过滤查询操作和db.updae()更新数据库记录遇到的坑。的更多相关文章

  1. windows下mongodb基础玩法系列二CURD操作(创建、更新、读取和删除)

    windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...

  2. flask 使用Flask-Migrate迁移数据库(创建迁移环境、生成迁移脚本、更新数据库)

    使用Flask-Migrate迁移数据库 在开发时,以删除表再重建的方式更新数据库简单直接,但明显的缺陷是会丢掉数据库中的所有数据.在生产环境下,没有人想把数据都删除掉,这时需要使用数据库迁移工具来完 ...

  3. MongoDB源码分析——mongod数据查询操作

    源码版本为MongoDB 2.6分支 Edit mongod数据查询操作 在mongod的初始化过程中说过,服务端接收到客户端消息后调用MyMessageHandler::process函数处理消息. ...

  4. [Spring Data MongoDB]学习笔记--MongoTemplate查询操作

    查询操作主要用到两个类:Query, Criteria 所有的find方法都需要一个query的object. 1. 直接通过json来查找,不过这种方式在代码中是不推荐的. BasicQuery q ...

  5. MongoDB(9)- 文档查询操作之 find() 的简单入门

    find() MongoDB 中查询文档使用 find() find() 方法以非结构化的方式来显示所要查询的文档 语法格式 db.collection.find(query, projection) ...

  6. MySQL、MongoDB、Redis 数据库之间的区别与使用(本章迭代更新)

    MySQL.MongoDB.Redis 数据库之间的区别与使用 MySQL.MongoDB.Redis 数据库之间的区别与使用(本章迭代更新) update:2019年2月20日 15:21:19(本 ...

  7. 分享知识-快乐自己:Hibernate各种查询操作

    Hibernate各种查询操作(一) 测试数据库如下: t_sort表:                                   t_good表: 一.对象导航方式查询 查询所有食品类下面 ...

  8. ocdefirst安装更新数据库

    数据迁移(Migrations) 启用数据迁移在控制台中输入如下命令:Enable-Migrations 这时会在项目目录中增加一个Migrations文件夹,里面放置了两个文件:EF会通过C#代码的 ...

  9. C# 使用Code First迁移更新数据库

    三步完成迁移: 1. 启用迁移: Enable-Migrations Enable-Migrations -ContextTypeName Mvc4WebSite.Models.MvcGuestboo ...

随机推荐

  1. 牛客挑战赛46 D

    题目链接: 数列 查询有多少\([l,r]\)区间满足每个数出现\(k\)的倍数次 即为\(1\)到\(r\)与\(1\)到\(l-1\)每个数相减的次数为\(k\)的倍数次 可以使用哈希维护 记录每 ...

  2. [日常摸鱼]Uva11178Morley's Theorem-几何

    题意:给一个$\Delta ABC$,分别做三个角的三等分线相交成$\Delta DEF$,求出$D,E,F$的坐标. 直接根据题意模拟 #include<cstdio> #include ...

  3. IDEA的基本操作——导入导出jar包

    在使用Jmeter工具测试时,有时也需要导出jar包,测试对应功能,或者自己二次开发Jmeter工具,也是需要导出jar包的.既然经常用,所以就总结了下导入导出jar包的方法. 导入jar包 先打开i ...

  4. angular8

    @Component 装饰器告诉Angular , AppComponent 类是一个组件,装饰器的属性用于配置该组件的应用方式. selectot 属性告诉Angular如何在HTML文档中应用该组 ...

  5. 每日CSS_发光文本效果

    每日CSS_发光文本效果 2020_12_22 源码 1. 代码解析 1.1 html 代码片段 <h1> <span>今</span> <span>天 ...

  6. Centos8自动挂载U盘移动硬盘解决办法

    Centos默认是不能识别NTFS文件系统的U盘.移动硬盘的.查阅了很多资料讲到的都是需要安装ntfs-3g安装包. 安装完后每次插入移动存储介质时,都需要手动去挂载. 作为一个做技术的,如果不能解决 ...

  7. 类818tu.c微信小说分销系统设计之定时模板消息源码

    近期将出个系列讲解开发过程,同时作为此系统的开发记录吧,万能的博客园,本边讲解如何发送模板消息,并且能够定时发送,下一篇讲解如何处理多个公众号的网页授权登录问题 [后台]http://xiaoshuo ...

  8. Selenium Web元素操作

    我们定位到Web页面元素之后,可以对元素进行一系列的操作,实现跟页面的交互.包括点击.文本输入.元素属性获取等.常用的方法列举如下: 方法 描述 click() 点击元素 send_keys(**va ...

  9. Android OpenGL ES 开发:绘制图形

    OpenGL 绘制图形步骤 上一篇介绍了 OpenGL 的相关概念,今天来实际操作,使用 OpenGL 绘制出图形,对其过程有一个初步的了解. OpenGL 绘制图形主要概括成以下几个步骤: 创建程序 ...

  10. intellij idea svn不能更新和提交

    进入设置–version control – subversion如下图,将前边的选项的勾全部去掉,点击ok