首页 > 解决方案 > 使用当前日期作为条件从 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 是开始日期变量,我检查开始变量是否等于当前日期变量,如果是,则返回这些事件,否则没有当前日期事件。但是即使数据库中有数据,我编写的代码也不会获取数据。

标签: javascriptangulargoogle-cloud-firestoreangularfire2

解决方案


当您在 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)
    

推荐阅读