首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在mongoDB中获取日期差异?日期应该是不同的天数吗?

如何在mongoDB中获取日期差异?日期应该是不同的天数吗?
EN

Stack Overflow用户
提问于 2018-01-02 14:47:20
回答 1查看 222关注 0票数 1

我想根据减去当前日期小于10天的过期日期对象来过滤集合。

我正在使用下面的代码,但我得到了以毫秒为单位的日期差异。我想要精确的日期差异。

代码语言:javascript
复制
db.metaobject.aggregate( 
    { $unwind :'$certifications.expiry_date'},
    {$project:{
            _id:1,name:1,date-Difference: { $divide:[ {$subtract: [ "$certifications.expiry_date",new Date ]},86400000] }
        }
    },
    {$match:{
          dateDifference:{$lte:10}
        }
    }

)
EN

回答 1

Stack Overflow用户

发布于 2018-01-02 22:03:22

如果在node中使用,则不需要计算差值:

直接计算节点js中的日期+ 10,然后直接计算到$lte:

代码语言:javascript
复制
var date = new Date();
var date10 = new Date(date.getTime());
date10.setDate(date10.getDate() + 10);

db.metaobject.aggregate( 
{ $unwind :'$certifications.expiry_date'},

{$match:{
      dateDifference:{$lte: new Date(date10).toJSON()}
    }
}

)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48056664

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档