微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

node.js – 在Mongoose中,如何过滤对象数组

我有以下架构:

var sampleSchema = new Schema({
  name: String,dates: [{
    date: Date,duration: Number
  }]
});

我需要根据以下规则过滤记录:如果其中一个日期晚于给定日期date_begin,请保留记录,否则不要.

我的印象是$gte或$lte是我需要的功能,但我找不到正确使用它们的方法.我试过了

sampleSchema.find({date_begin: {$gte: 'date'}});

或者它的一些变体,但我似乎无法使它工作.任何人都知道我应该怎么做?

解决方法

查询数组内的元素,使用 $elemMatch

SampleModel.find( { dates : { $elemmatch: {  date : { $gte: 'DATE_VALUE' } } } } )

如果你使用的是single query condition,你可以直接过滤:

SampleModel.find( { 'dates.date': { $gte: 'DATE_VALUE' } } )

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐