jjzjj

javascript - $pull mongodb 没有删除项目

coder 2024-07-13 原文

我有一个收藏:

//the json.
{
"ItemsToDelete" : [ 
        {
            "placeId" : "ChIJIQBpAG2ahYAR_6128GcTUEo",
            "users" : [ 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15")
            ]
        }, 
        {
            "placeId" : "ChIJIQBpAG2ahYAR_6128GcTUEo",
            "users" : [ 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15")
            ]
        }, 
        {
            "placeId" : "ChIJIQBpAG2ahYAR_6128GcTUEo",
            "users" : [ 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15")
            ]
        }
    ]
}  


{
"ItemsToRemove" : [ 
        {
            "ChIJIQBpAG2ahYAR_6128GcTUEo" : [ 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15")
            ]
        }, 
        {
            "ChIJIQBpAG2ahYAR_6128GcTUEo" : [ 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15")
            ]
        }, 
        {
            "ChIJIQBpAG2ahYAR_6128GcTUEo" : [ 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15"), 
                ObjectId("547e4650f3fb0a022110af15")
            ]
        }
    ]
}

然后我运行这个 mongo shell 查询从数组中提取一个项目并删除:

db.users.update({"_id":ObjectId("54e664c4e7c3b4d3b5413e39")},{$pull:{ItemsToDelete : {placeId:"ChIJIQBpAG2ahYAR_6128GcTUE"}}},{ multi: true })

数组保持不变。有什么想法为什么 $pull 失败了吗?

我已尝试“ItemsToDelete.placeId”,但出现错误:执行“ItemsToDelete.placeId”时收到的错误=>“无法使用部分(ItemsToDelete.placeId 的ItemsToDelete)遍历元素”

最佳答案

您的查询没有提取任何项目,因为您在 placeId 值中缺少 o

> db.users.update(
    {"_id":ObjectId("54e664c4e7c3b4d3b5413e39")},
    {$pull:{ItemsToDelete : {placeId:"ChIJIQBpAG2ahYAR_6128GcTUE"}}},
                                                                ^
    { multi: true }
  )

应该是

> db.users.update(
    {"_id":ObjectId("54e664c4e7c3b4d3b5413e39")},
    {$pull:{ItemsToDelete : {placeId:"ChIJIQBpAG2ahYAR_6128GcTUEo"}}},
    { multi: true }
  )

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.users.find().pretty()
{ "_id" : ObjectId("54eac8d51a0c74438c9dea10"), "ItemsToDelete" : [ ] }

关于javascript - $pull mongodb 没有删除项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28663273/

有关javascript - $pull mongodb 没有删除项目的更多相关文章

  1. ruby - 如何在 buildr 项目中使用 Ruby 代码? - 2

    如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby​​

  2. ruby - 难道Lua没有和Ruby的method_missing相媲美的东西吗? - 2

    我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/

  3. ruby-on-rails - 如何从 format.xml 中删除 <hash></hash> - 2

    我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为

  4. ruby - 我可以使用 Ruby 从 CSV 中删除列吗? - 2

    查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html

  5. ruby-on-rails - rails 目前在重启后没有安装 - 2

    我有一个奇怪的问题:我在rvm上安装了ruby​​onrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(

  6. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

    我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

  7. ruby - 我可以使用 aws-sdk-ruby 在 AWS S3 上使用事务性文件删除/上传吗? - 2

    我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的

  8. ruby-on-rails - 项目升级后 Pow 不会更改 ruby​​ 版本 - 2

    我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby​​版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby​​版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘

  9. ruby-on-rails - 新 Rails 项目 : 'bundle install' can't install rails in gemfile - 2

    我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="

  10. Ruby 从大范围中获取第 n 个项目 - 2

    假设我有这个范围:("aaaaa".."zzzzz")如何在不事先/每次生成整个项目的情况下从范围中获取第N个项目? 最佳答案 一种快速简便的方法:("aaaaa".."zzzzz").first(42).last#==>"aaabp"如果出于某种原因你不得不一遍又一遍地这样做,或者如果你需要避免为前N个元素构建中间数组,你可以这样写:moduleEnumerabledefskip(n)returnto_enum:skip,nunlessblock_given?each_with_indexdo|item,index|yieldit

随机推荐