Mongoose条件查询某个时间段的数据

Mongoose查询某个时间段的数据

今天在写东西的时候需要实现一个数据搜索的功能,其中有按时间条件查找的需求,在这里写一下实现的思路。

首先,按时间查询一般都是查找的某个区间值的数据,所有主要有以下几种情况:

  1. A-B之间的数据;
    例如:2020年6月1号的数据,实际是6月1号0点到6月2号0点之间的所有数据。
  2. A之前的数据;
    例如:一月之前的数据,实际是小于 当前时间往前推一个月 的时间节点的所有数据。
  3. A之后的数据
    例如:一周之内的数据,实际是大于 当前时间往前推一周 的时间节点的所有数据。

代码如何实现呢?
我们主要是使用 $gt$lt这两个操作,$gt的意思是大于某个值,$lt的意思是小于某个值。

具体代码如下:

Model.find({ createdAt: { $gt: startTime } });		//实现第三种情况
Model.find({ createdAt: { $lt: endTime } });		//实现第二种情况
Model.find({ $and: [{ createdAt: { $gt: startTime } }, { createdAt: { $lt: endTime } }] });		//实现第一种情况

其中createdAt是mongoose数据库中存储数据时的默认时间戳字段,createdAt表示的是数据创建时的时间。startTime表示的是查询条件的起始时间,endTime表示的是结束时间。$and是与的意思,表示同时满足后面的条件。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值