首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在firebase中查询startAt和endAt中的日期

在Firebase中,startAt()endAt() 方法用于对查询结果进行范围过滤

首先,确保你的 Firebase 项目已经启用了 Realtime Database 或 Cloud Firestore,并且你已经设置了正确的规则以允许读取数据。

对于 Realtime Database:

假设你有一个名为 events 的节点,其中包含按日期存储的事件数据,如下所示:

代码语言:javascript
复制
{
  "events": {
    "-MkYg...": {
      "name": "Event 1",
      "date": "2022-01-01"
    },
    "-MkJH...": {
      "name": "Event 2",
      "date": "2022-01-02"
    },
    ...
  }
}

你可以使用以下查询来获取指定日期范围内的事件:

代码语言:javascript
复制
const firebase = require('firebase/app');
require('firebase/database');

const firebaseConfig = {
  // Your Firebase config here
};

firebase.initializeApp(firebaseConfig);
const database = firebase.database();

const startDate = '2022-01-01';
const endDate = '2022-01-31';

database.ref('events')
  .orderByChild('date')
  .startAt(startDate)
  .endAt(endDate)
  .once('value', (snapshot) => {
    const events = snapshot.val();
    console.log(events);
  });

对于 Cloud Firestore:

假设你有一个名为 events 的集合,其中包含按日期存储的事件数据,如下所示:

代码语言:javascript
复制
{
  "events": [
    {
      "name": "Event 1",
      "date": "2022-01-01"
    },
    {
      "name": "Event 2",
      "date": "2022-01-02"
    },
    ...
  ]
}

你可以使用以下查询来获取指定日期范围内的事件:

代码语言:javascript
复制
const firebase = require('firebase/app');
require('firebase/firestore');

const firebaseConfig = {
  // Your Firebase config here
};

firebase.initializeApp(firebaseConfig);
const firestore = firebase.firestore();

const startDate = '2022-01-01';
const endDate = '2022-01-31';

firestore.collection('events')
  .orderBy('date')
  .startAt(startDate)
  .endAt(endDate)
  .get()
  .then((snapshot) => {
    const events = snapshot.docs.map(doc => doc.data());
    console.log(events);
  });

请注意,startAt()endAt() 方法默认情况下会包含边界值。如果你想要排除边界值,可以使用 startAfter()endBefore() 方法。

另外,为了提高查询性能,建议在 date 字段上创建索引。在 Realtime Database 中,这通常是自动完成的。在 Cloud Firestore 中,你需要在 Firebase 控制台中手动创建索引。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

2分35秒

146_尚硅谷_MySQL基础_演示delete和truncate在事务中的区别

1分29秒

在Flask框架中,Response对象的`__bool__`和`__nonzero__`方法被重载

14分25秒

062_第六章_Flink中的时间和窗口(二)_水位线(三)_水位线在代码中的生成(一)

8分48秒

063_第六章_Flink中的时间和窗口(二)_水位线(三)_水位线在代码中的生成(二)

2分35秒

146_尚硅谷_MySQL基础_演示delete和truncate在事务中的区别.avi

3分0秒

四轴飞行器在ROS、Gazebo和Simulink中的路径跟踪和障碍物规避

6分22秒

17-在idea中能够创建mybatis核心配置文件和映射文件的模板

27分24秒

051.尚硅谷_Flink-状态管理(三)_状态在代码中的定义和使用

13分46秒

16.尚硅谷-IDEA-版本控制在IDEA中的配置和使用.avi

13分46秒

16.尚硅谷-IDEA-版本控制在IDEA中的配置和使用.avi

34秒

振弦传感器和信号转换器在桥梁安全监测中的重要性

16分21秒

136_第十一章_Table API和SQL(四)_流处理中的表(一)_动态表和持续查询

领券