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

查询MongoDB的日期时,TypeORM返回空数组

如何解决查询MongoDB的日期时,TypeORM返回空数组

我有以下查询,该查询应该从我的MongoDB中获取具有将来HospitalizedUntil日期的对象:

        return await this.hospitalRepository.find({
        where: {
            hospitalizedUntil: MoreThanDate(new Date(),EDateType.Datetime)
        }
    });

更多日期:

const MoreThanDate = (date: Date,type: EDateType) => MoreThan(format(date,type));

但是,此查询不会返回任何对象,即使Mongo中将来有一个对象也可以将HospitaledUntil放置在该对象中: (当前日期时间:2020-08-28T17:11:09.888Z)

[
  Hospital {
    _id: 5f492efd50e81f63dc60c5d3,discordId: 'xxxxxxxxxxxxxxxxx',hospitalizedUntil: 2020-08-28T18:51:17.627Z,reason: 'Was robbed',hospitalizedBy: 'xxxxxxxxxxxxxxxxx'
  }
]

我也尝试过使用Between运算符:

    where: {
        hospitalizedUntil: Between(new Date(),new Date('9999-12-31'))
    }

但这也会返回一个空数组。

解决方法

遇到了同样的问题,使用原生 mongoDB 查询解决了。

hospitalizedUntil: { $gte: format(new Date(),EDateType.Datetime) }

我认为这些函数在 mongoDB 上不起作用(尽管我没有发现与该问题相关的任何内容)

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