http://blog.csdn.net/yaomingyang/article/details/78701643

一、$pull修饰符会删除掉数组中符合条件的元素,使用的格式是:

  1. { $pull: { <field1>: <value|condition>, <field2>: <value|condition>, ... } }

二、指定一个值删除所有的列表

给一个stores集合下的文档

  1. {
  2. _id: 1,
  3. fruits: [ "apples", "pears", "oranges", "grapes", "bananas" ],
  4. vegetables: [ "carrots", "celery", "squash", "carrots" ]
  5. }
  6. {
  7. _id: 2,
  8. fruits: [ "plums", "kiwis", "oranges", "bananas", "apples" ],
  9. vegetables: [ "broccoli", "zucchini", "carrots", "onions" ]
  10. }

如下操作更新所有的文档在集合stores中的"apples"和"oranges"在数组fruits中和删除数组vegetables中的"carrots"

  1. db.stores.update(
  2. { },
  3. { $pull: { fruits: { $in: [ "apples", "oranges" ] }, vegetables: "carrots" } },
  4. { multi: true }
  5. )

操作后的结果是:

  1. {
  2. "_id" : 1,
  3. "fruits" : [ "pears", "grapes", "bananas" ],
  4. "vegetables" : [ "celery", "squash" ]
  5. }
  6. {
  7. "_id" : 2,
  8. "fruits" : [ "plums", "kiwis", "bananas" ],
  9. "vegetables" : [ "broccoli", "zucchini", "onions" ]
  10. }

三、$pull删除所有符合条件的元素

根据集合profiles集合文档

  1. { _id: 1, votes: [ 3, 5, 6, 7, 7, 8 ] }

如下操作会删除掉votes数组中元素大于等于6的元素

  1. db.profiles.update( { _id: 1 }, { $pull: { votes: { $gte: 6 } } } )

操作 之后数组中都是小于6的元素

  1. { _id: 1, votes: [  3,  5 ] }

四、从一个数组嵌套文档中删除元素

一个survey集合包含如下文档

  1. {
  2. _id: 1,
  3. results: [
  4. { item: "A", score: 5 },
  5. { item: "B", score: 8, comment: "Strongly agree" }
  6. ]
  7. }
  8. {
  9. _id: 2,
  10. results: [
  11. { item: "C", score: 8, comment: "Strongly agree" },
  12. { item: "B", score: 4 }
  13. ]
  14. }

如下操作将会删除掉数组results中元素item等于B、元素score等于8的文档集合

  1. db.survey.update(
  2. { },
  3. { $pull: { results: { score: 8 , item: "B" } } },
  4. { multi: true }
  5. )

操作后的结果是:

  1. {
  2. "_id" : 1,
  3. "results" : [ { "item" : "A", "score" : 5 } ]
  4. }
  5. {
  6. "_id" : 2,
  7. "results" : [
  8. { "item" : "C", "score" : 8, "comment" : "Strongly agree" },
  9. { "item" : "B", "score" : 4 }
  10. ]
  11. }

五、如下集合文档是数组套数组类型

  1. {
  2. _id: 1,
  3. results: [
  4. { item: "A", score: 5, answers: [ { q: 1, a: 4 }, { q: 2, a: 6 } ] },
  5. { item: "B", score: 8, answers: [ { q: 1, a: 8 }, { q: 2, a: 9 } ] }
  6. ]
  7. }
  8. {
  9. _id: 2,
  10. results: [
  11. { item: "C", score: 8, answers: [ { q: 1, a: 8 }, { q: 2, a: 7 } ] },
  12. { item: "B", score: 4, answers: [ { q: 1, a: 0 }, { q: 2, a: 8 } ] }
  13. ]
  14. }

可以使用$elemMatch匹配多个条件

  1. db.survey.update(
  2. { },
  3. { $pull: { results: { answers: { $elemMatch: { q: 2, a: { $gte: 8 } } } } } },
  4. { multi: true }
  5. )

操作后的结果是:

  1. {
  2. "_id" : 1,
  3. "results" : [
  4. { "item" : "A", "score" : 5, "answers" : [ { "q" : 1, "a" : 4 }, { "q" : 2, "a" : 6 } ] }
  5. ]
  6. }
  7. {
  8. "_id" : 2,
  9. "results" : [
  10. { "item" : "C", "score" : 8, "answers" : [ { "q" : 1, "a" : 8 }, { "q" : 2, "a" : 7 } ] }
  11. ]
  12. }

Mongodb更新数组$pull修饰符的更多相关文章

  1. Mongodb更新数组$pull修饰符 (mongodb 修改器($inc/$set/$unset/$push/$pop/upsert))

    mongodb 修改器($inc/$set/$unset/$push/$pop/upsert))   https://www.jb51.net/article/112588.htm http://bl ...

  2. iOS 属性修饰符记录 --不定时更新

    重新审视了一下OC在属性修饰符,特意记录一下来.以后不定时更新 > retain:只有在非ARC下才会有效,所有如果在ARC下使用了retain修饰也白搭 如以下的data属性用retain修饰 ...

  3. vue中.sync修饰符,实现子组件实时更新父组件的值

    vue 修饰符sync的功能是:当一个子组件改变了一个 prop 的值时,这个变化也会同步到父组件中所绑定. 不过它有一个前身,先来看看.sync出现之前是如何实现的 父组件中(传递给子组件一个值:p ...

  4. C语言回顾-整型变量修饰符和一维数组

    1.整型变量修饰符 1)改变整型变量的存储空间 #include <stdio.h> int main(int argc, const char * argv[]) { //改变整型变量占 ...

  5. EffectiveC#02--仅在对基类进行强制更新时才使用new修饰符

    1.建议避免使用new修饰符来重新定义非虚函数. 非虚方法是静态绑定的,不管哪里的代码也不管在哪里引用, 它总是严格的调用类中所定义的函数.并不会在运行时在 派生类中查找不同的版本. 2.何时使用ne ...

  6. MongoDB学习day08--mongoose预定义修饰符和getter、setter修饰符

    一.mongoose预定义修饰符 lowercase. uppercase . trim var UserSchema=mongoose.Schema({ name:{ type:String, tr ...

  7. C#基础回顾(一)—C#访问修饰符

    一.写在前面的话 好久没有停下来总结自己,转眼间15年过去好些天,回首过去的日子,亦或失去,亦或所得!生活的节奏,常常让我们带着急急忙忙的节奏去追赶,也许这并不是每个人所期望的生活方式!于他人,于自己 ...

  8. Vue.js学习笔记(三) - 修饰符

    本篇将简单介绍常用的修饰符. 在上一篇中,介绍了 v-model 和 v-on 简单用法.除了常规用法,这些指令也支持特殊方式绑定方法,以修饰符的方式实现.通常都是在指令后面用小数点“.”连接修饰符名 ...

  9. ch3-模板语法({{}} v-html v-bind:id 表达式 指令 修饰符 过滤器)

    1 模板语法 Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据. 所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器 ...

随机推荐

  1. Android Logcat Security(转)

    讲解了在Android开发中logcat使用不当导致的安全问题 原帖地址:http://drops.wooyun.org/tips/3812 0x00 科普 development version : ...

  2. minishift的本地代码构建

    看文档说支持,但实际尝试了下,失败 发现仍然是找github中的代码 找了半天,发现是在目录下有.git的隐含目录,然后copy到其他目录下删除,然后再试,发现仍然失败. 日志看是指定的目录并没有传入 ...

  3. linux下使用C++ Json库

    安装Json库 1.下载JsonCpphttp://sourceforge.net/projects/jsoncpp/files/ 2.下载sconshttp://sourceforge.net/pr ...

  4. python查看字节码

    查看字节码可以帮助我们更好的理解python的执行流程 查看字节码列表 import opcode for op in range(len(opcode.opname)): print('0x%.2X ...

  5. 理解Vue的状态管理模式Vuex

    Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 状态管理模式.集中式存储管理,一听就很高大 ...

  6. phpcms v9自定义HTML文件名

    用过织梦.Wordpress.Zblog等程序的网友都知道,发布内容的时候可以自定义生成的HTML文件名,这个功能对于SEO来说非常有好 处,但是到了V9之后却很遗憾, 这个功能却没有了,现在你只要对 ...

  7. 配置thinkphp3.2 404页面

    ThinkPHP自身提供了 404 页面的处理机制,我们只需要在控制器 中添加一个 EmptyController.class.php,并且实现以下方法即可,方法如下: <? class  Em ...

  8. Hadoop Maven pom文件示例

    Hadoop Maven pom文件示例 @(Hadoop) <?xml version="1.0" encoding="UTF-8"?> < ...

  9. Spring框架学习(3)spring中使用jdbc

    内容源自:spring中使用jdbc spring dao层中对jdbc进行了封装,使用模板模式的设计模式,通过ioc被动注入的方式将jdbcTemplate这个模板类注入到数据对象中,进行数据库操作 ...

  10. os.waitpid()无法获取sys.exit()退出时的status code

    [目的] 父进程使用os.waitpid()等待子进程退出,并检测子进程的exit code,以决定是否重启子进程. (常见的应用场景是:子进程接收外部命令,收到"stop"时退出 ...