javascript - 使用当前日期作为条件从 firebase 检索数据
问题描述
我需要通过将当前日期与我的 firestore 数据库中名为 start date 的属性进行比较来检索数据。我只需要检索与当前日期值与开始日期匹配的数据。我创建了一个查询来检索数据,但我无法使用该查询检索任何数据。
事件模型.ts
export interface Events{
title:String;
start:Date;
end:Date;
}
app.component.ts
event$:Observable<Events[]>;
const newDate = firebase.firestore.Timestamp.fromDate(new Date()).toDate();
this.event$ = this.firestore.collection<Events>('eventsCalender',
ref => ref.where('start','==',newDate)).valueChanges();
this.event$.subscribe(data => console.log(data));
我创建了一个接口并导出,并在 app.component.ts 中实现了检索事件的查询。start 是开始日期变量,我检查开始变量是否等于当前日期变量,如果是,则返回这些事件,否则没有当前日期事件。但是即使数据库中有数据,我编写的代码也不会获取数据。
解决方案
当您在 Firestore 中存储日期时,它会以微秒的粒度存储。new Date()
当您在 JavaScript 中创建 a时,它具有毫秒粒度。在不同时刻创建的两个这样的日期完全相等的机会非常小。
您通常需要执行以下操作之一:
- 存储四舍五入到特定粒度的所有日期。例如:如果您只想存储日期而不是时间,则可以确保将所有日期字段存储为该日期的午夜。然后在您的查询中,您可以执行以下操作:
var newDate = new Date(); newDate.setHours(0,0,0,0);
将午夜与午夜进行比较。 查询范围。例如:要获取开始日期为今天的所有字段,您可以执行以下操作:
var startOfToday = new Date(); startOfToday.setHours(0,0,0,0); var endOfToday = new Date(); endOfToday.setHours(23,59,59,999); ref.where('start','>=',startOfToday).where('start', '<=', endOfToday)
推荐阅读
- matlab - 如何在 Matlab 中选择要使用滑块绘制的数据?
- php - wordpress 简单的工作板插件隐藏简历附件表单
- java - 无法从浏览器访问 localhost:8080 公用文件夹(java spring boot)
- android - 如果我发布具有不同应用标题的更新,该应用是否会在 Google Play 商店中处于非活动状态?
- php - 为什么即使文件存在,我的 curl 请求也不上传文件?
- python - Jupyter notebook 使输入单元格可滚动
- c++ - ofstream 无法根据文件大小打开现有文件
- html - 如何在不移动标题的情况下将此徽标移动到我的标题上?
- java - 仅基于选定的微调器项目设置文本值
- anylogic - AnyLogic 的控制应用程序