Mongodb更新数组$pull修饰符
一、$pull修饰符会删除掉数组中符合条件的元素,使用的格式是:
- { $pull: { <field1>: <value|condition>, <field2>: <value|condition>, ... } }
二、指定一个值删除所有的列表
给一个stores集合下的文档
- {
- _id: 1,
- fruits: [ "apples", "pears", "oranges", "grapes", "bananas" ],
- vegetables: [ "carrots", "celery", "squash", "carrots" ]
- }
- {
- _id: 2,
- fruits: [ "plums", "kiwis", "oranges", "bananas", "apples" ],
- vegetables: [ "broccoli", "zucchini", "carrots", "onions" ]
- }
如下操作更新所有的文档在集合stores中的"apples"和"oranges"在数组fruits中和删除数组vegetables中的"carrots"
- db.stores.update(
- { },
- { $pull: { fruits: { $in: [ "apples", "oranges" ] }, vegetables: "carrots" } },
- { multi: true }
- )
操作后的结果是:
- {
- "_id" : 1,
- "fruits" : [ "pears", "grapes", "bananas" ],
- "vegetables" : [ "celery", "squash" ]
- }
- {
- "_id" : 2,
- "fruits" : [ "plums", "kiwis", "bananas" ],
- "vegetables" : [ "broccoli", "zucchini", "onions" ]
- }
三、$pull删除所有符合条件的元素
根据集合profiles集合文档
- { _id: 1, votes: [ 3, 5, 6, 7, 7, 8 ] }
如下操作会删除掉votes数组中元素大于等于6的元素
- db.profiles.update( { _id: 1 }, { $pull: { votes: { $gte: 6 } } } )
操作 之后数组中都是小于6的元素
- { _id: 1, votes: [ 3, 5 ] }
四、从一个数组嵌套文档中删除元素
一个survey集合包含如下文档
- {
- _id: 1,
- results: [
- { item: "A", score: 5 },
- { item: "B", score: 8, comment: "Strongly agree" }
- ]
- }
- {
- _id: 2,
- results: [
- { item: "C", score: 8, comment: "Strongly agree" },
- { item: "B", score: 4 }
- ]
- }
如下操作将会删除掉数组results中元素item等于B、元素score等于8的文档集合
- db.survey.update(
- { },
- { $pull: { results: { score: 8 , item: "B" } } },
- { multi: true }
- )
操作后的结果是:
- {
- "_id" : 1,
- "results" : [ { "item" : "A", "score" : 5 } ]
- }
- {
- "_id" : 2,
- "results" : [
- { "item" : "C", "score" : 8, "comment" : "Strongly agree" },
- { "item" : "B", "score" : 4 }
- ]
- }
五、如下集合文档是数组套数组类型
- {
- _id: 1,
- results: [
- { item: "A", score: 5, answers: [ { q: 1, a: 4 }, { q: 2, a: 6 } ] },
- { item: "B", score: 8, answers: [ { q: 1, a: 8 }, { q: 2, a: 9 } ] }
- ]
- }
- {
- _id: 2,
- results: [
- { item: "C", score: 8, answers: [ { q: 1, a: 8 }, { q: 2, a: 7 } ] },
- { item: "B", score: 4, answers: [ { q: 1, a: 0 }, { q: 2, a: 8 } ] }
- ]
- }
可以使用$elemMatch匹配多个条件
- db.survey.update(
- { },
- { $pull: { results: { answers: { $elemMatch: { q: 2, a: { $gte: 8 } } } } } },
- { multi: true }
- )
操作后的结果是:
- {
- "_id" : 1,
- "results" : [
- { "item" : "A", "score" : 5, "answers" : [ { "q" : 1, "a" : 4 }, { "q" : 2, "a" : 6 } ] }
- ]
- }
- {
- "_id" : 2,
- "results" : [
- { "item" : "C", "score" : 8, "answers" : [ { "q" : 1, "a" : 8 }, { "q" : 2, "a" : 7 } ] }
- ]
- }
Mongodb更新数组$pull修饰符的更多相关文章
- 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 ...
- iOS 属性修饰符记录 --不定时更新
重新审视了一下OC在属性修饰符,特意记录一下来.以后不定时更新 > retain:只有在非ARC下才会有效,所有如果在ARC下使用了retain修饰也白搭 如以下的data属性用retain修饰 ...
- vue中.sync修饰符,实现子组件实时更新父组件的值
vue 修饰符sync的功能是:当一个子组件改变了一个 prop 的值时,这个变化也会同步到父组件中所绑定. 不过它有一个前身,先来看看.sync出现之前是如何实现的 父组件中(传递给子组件一个值:p ...
- C语言回顾-整型变量修饰符和一维数组
1.整型变量修饰符 1)改变整型变量的存储空间 #include <stdio.h> int main(int argc, const char * argv[]) { //改变整型变量占 ...
- EffectiveC#02--仅在对基类进行强制更新时才使用new修饰符
1.建议避免使用new修饰符来重新定义非虚函数. 非虚方法是静态绑定的,不管哪里的代码也不管在哪里引用, 它总是严格的调用类中所定义的函数.并不会在运行时在 派生类中查找不同的版本. 2.何时使用ne ...
- MongoDB学习day08--mongoose预定义修饰符和getter、setter修饰符
一.mongoose预定义修饰符 lowercase. uppercase . trim var UserSchema=mongoose.Schema({ name:{ type:String, tr ...
- C#基础回顾(一)—C#访问修饰符
一.写在前面的话 好久没有停下来总结自己,转眼间15年过去好些天,回首过去的日子,亦或失去,亦或所得!生活的节奏,常常让我们带着急急忙忙的节奏去追赶,也许这并不是每个人所期望的生活方式!于他人,于自己 ...
- Vue.js学习笔记(三) - 修饰符
本篇将简单介绍常用的修饰符. 在上一篇中,介绍了 v-model 和 v-on 简单用法.除了常规用法,这些指令也支持特殊方式绑定方法,以修饰符的方式实现.通常都是在指令后面用小数点“.”连接修饰符名 ...
- ch3-模板语法({{}} v-html v-bind:id 表达式 指令 修饰符 过滤器)
1 模板语法 Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据. 所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器 ...
随机推荐
- fedora19/opensuse13.1 配置svn client
Date: 20140208Auth: Jin 一.install zypper install subversion yum install subversion 二.操作 1.将文件check ...
- 通过Ollydbg定位私有协议通信明文
简介:做安全的筒子经常会碰到这样的问题,当向要分析通信协议的时候往往都会有加密通信保护,对于SSL通信我们可以使用SSL劫持,但对于应用层面的加密就显得无能为力了,最好的办法就是调试应用,在应用内部去 ...
- dns问题,QQ打得开,网页打不开
dns问题,QQ打得开,网页打不开 ip4 dns 改为114.114.114.114. 原因有可能是路由出错之类的.114是默认的通用ip
- minGW cygwin gnuwin32
首先,三个的官方网站分别是: minGW:http://www.mingw.org cygwin: http://www.cygwin.com gnuwin32: https://sourcefo ...
- List of regional organizations by population
https://baike.baidu.com/item/国际组织/261053?fr=aladdin 经济文化类组织(非政府组织) 创行 狮子会 全球青年领导力联盟 乐施会 政治类组织 欧洲联盟(欧 ...
- html Frame、Iframe、Frameset 的区别 详细出处参考:http://www.jb51.net/web/22785.html
10.4.1 Frameset与Frame的区别首先讲解Frameset与Frame之间的区别. 用来划分框架,每一个框架由标记.必须在之内使用,代码如下: 在上面的例子当中,把页面分为左右两个部分, ...
- [Todo]各种语言包管理工具
看到一篇文章不错: http://harttle.com/2015/05/29/pkg-manager.html 包管理和构建系统是现代的软件开发团队中必不可少的工具,也是Linux软件系统的常见组织 ...
- request.startAsync()不支持异步操作
Servlet3.0使用异步处理时,后台报错: java.lang.IllegalStateException: A filter or servlet of the current chain do ...
- scrapy-splash抓取动态数据例子七
一.介绍 本例子用scrapy-splash抓取36氪网站给定关键字抓取咨询信息. 给定关键字:个性化:融合:电视 抓取信息内如下: 1.资讯标题 2.资讯链接 3.资讯时间 4.资讯来源 二.网站信 ...
- java中class.forName和classLoader加载类的区分
java中class.forName和classLoader都可用来对类进行加载.前者除了将类的.class文件加载到jvm中之外,还会对类进行解释,执行类中的static块.而classLoade ...