如何解决查询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] 举报,一经查实,本站将立刻删除。