草庐IT

node.js - Mongoose 查找 $in 查询不工作

coder 2023-11-01 原文

我有一些看起来像这样的代码

return courseModel.findQ({ autoReview: true}).then(function(autoCourses){
            autoCourses = _.pluck(autoCourses, '_id');

            console.log("autoCourses", autoCourses);

            return userCoursesModel.findQ({ 
                activityId: { 
                    $in: autoCourses
                }
            }).then(function(ucs) {
                var saves = [];

                console.log("ucs", ucs);

当我登录“autoCourses”时,我看到打印了一些文档,并且 lodash pluck 应该会提取每个文档的 _id。我确认这工作正常。

我正在使用 mongoose-q:

https://github.com/iolo/mongoose-q

我也尝试了正常的“查找”,但没有成功。

当我执行 findQ({}) 并找到所有文档时,我可以看到与 activityId 匹配的文档。例如:

autoCourses [ 55d3b57e395d0105a4828f18,
  55d4e0b8df5d4cdc23c916e2,
  55d23654642c1d05124c1ace,
  55d238b0642c1d05124c1ad2,
  55d23bb1ecce9f4b14f79c7b,
  55d257cf70721efc16db1c24,
  55d2682532eace3118376a95,
  55d2694a32eace3118376aad,

此外,当我使用 findAll 记录每个用户类(class) activityId 时,我可以看到有匹配项:

ucs.activityId 55de1dedc7c10dfc3bf5d9ae
ucs.activityId 55d3a91d46206dde7a46ed94
ucs.activityId 55df9974d8dfddb877a372f9
ucs.activityId 55d3b57e395d0105a4828f18

这里发生了什么?为什么 $in 查询不起作用?

更新:

根据要求,这是用户类(class)架构的样子:

var UserCourseSchema = new Schema({
    activityId: {
        type: Schema.Types.ObjectId,
        ref: 'courses',
        required: true
    },

和类(class)

var CourseSchema = new Schema({
    autoReview: {
        type: Boolean,
        default: false
    },

创建用户类(class)文档:

var newUserCourse = {
                    userId : userId,
                    activityId : activity._id,
                    steps : []
                }
                // copy steps from activity
                activity.steps.forEach(function(step){
                    newUserCourse.steps.push({partId: step._id});
                })
                return UserCourses.createQ(newUserCourse);

最佳答案

我就此联系了 MongoDB 支持,我发现 mongoose-q 使用的是旧版本的 mongoose(< 版本="" 4),而我的顶级依赖项是="" 4.0.5,这导致了奇怪的行为。一旦我将="" mongoose-q="" 更新为="" 0.1.0="" 并将="" mongoose="" 更新为="" 4.1.6="">

关于node.js - Mongoose 查找 $in 查询不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32463906/

有关node.js - Mongoose 查找 $in 查询不工作的更多相关文章

  1. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  2. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  3. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  4. ruby - ECONNRESET (Whois::ConnectionError) - 尝试在 Ruby 中查询 Whois 时出错 - 2

    我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.

  5. ruby-on-rails - Rails 源代码 : initialize hash in a weird way? - 2

    在rails源中:https://github.com/rails/rails/blob/master/activesupport/lib/active_support/lazy_load_hooks.rb可以看到以下内容@load_hooks=Hash.new{|h,k|h[k]=[]}在IRB中,它只是初始化一个空哈希。和做有什么区别@load_hooks=Hash.new 最佳答案 查看rubydocumentationforHashnew→new_hashclicktotogglesourcenew(obj)→new_has

  6. ruby-on-rails - Rails 3 I18 : translation missing: da. datetime.distance_in_words.about_x_hours - 2

    我看到这个错误:translationmissing:da.datetime.distance_in_words.about_x_hours我的语言环境文件:http://pastie.org/2944890我的看法:我已将其添加到我的application.rb中:config.i18n.load_path+=Dir[Rails.root.join('my','locales','*.{rb,yml}').to_s]config.i18n.default_locale=:da如果我删除I18配置,帮助程序会处理英语。更新:我在config/enviorments/devolpment

  7. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  8. 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="

  9. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  10. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

随机推荐