art*_*rov 7 database-design firebase google-cloud-functions google-cloud-firestore
我想就以下场景的 Cloud Firestore 数据结构最佳实践寻求建议。
有一个预订/约会应用程序。酒店出租房间。每家酒店都有多个房间。客户可以根据特定日期的空房情况搜索所有酒店的房间。
在 Firestore 中构建可用性数据的最佳方法是什么,以便我可以创建所有酒店的所有可用房间的视图。
我想创建一个单独的集合,我将在其中放置所有引用room ID
和date
保留的保留。但是,似乎我无法以这种方式搜索可用插槽,因为 Firestore 无法执行“不等于”查询。
所以我想我会为每个房间创建一个数组字段,其中包含所有可用日期作为时间戳。这就产生了另一个问题。即使我可以使用“array_contains”查询,用户也不能通过这种方式检查超过一天的可用性,因为“array_contains”每个查询只能使用一次。
在这种情况下,构建数据的最有效方法是什么?
谢谢!
在 Firestore 中构建可用性数据的最佳方法是什么,以便我可以创建所有酒店的所有可用房间的视图。
一个可能的数据库结构可以帮助你实现你想要的,可能是这样的:
Firestore-root
|
--- hotels (collection)
| |
| --- hotelId (document)
| |
| --- //Hotel properties
|
|
--- rooms (collection)
| |
| --- hotelId (document)
| |
| --- hotelRooms (collection)
| |
| --- roomId (document)
| |
| --- available: true
| |
| --- hotel: "hotelId"
| |
| --- //Other room properties
|
|
--- availabeRooms (collection)
|
--- roomId (document)
|
--- available: true
|
--- hotel: "hotelId"
|
--- //Other room properties
Run Code Online (Sandbox Code Playgroud)
正如您可能看到的,我复制了一些数据以实现您想要的。这种做法被称为denormalization
Firebase 的常见做法。为了更好地理解,我建议您观看此视频,Firebase 数据库的非规范化是正常的。它适用于 Firebase 实时数据库,但同样的原则也适用于 Cloud Firestore。
此外,当您复制数据时,需要记住一件事。与添加数据的方式相同,您需要维护它。换句话说,如果你想更新/删除一个项目,你需要在它存在的每个地方都做。
使用此数据库模式,您可以通过在availabeRooms
引用上附加侦听器并获取所有房间对象来简单地查询数据库以获取所有酒店的所有可用房间。如果您想了解某个特定房间与其相隔的酒店的详细信息,则需要额外拨打电话以获取酒店的详细信息。我已经存储在房间对象中,只有一个酒店对象的引用,如您所见,hotelId
. 您也可以存储整个hotel
对象,但在做出决定之前,我建议您了解一些细节,这些细节可以在我从这篇文章中找到的答案中找到。
此外,如果房间变得不可用,只需将available
存在的属性值更改rooms -> hotelId -> hotelRooms -> roomId
为false
并从availabeRooms
集合中删除相应的房间。就是这样!
PS 如果您想获取单个酒店内的所有可用房间,只需附加一个侦听器rooms -> hotelId -> hotelRooms
并使用应如下所示的查询获取所有可用房间:
Query query = db.collection("rooms").document(hotelId)
.collection("hotelRooms").whereEqualTo("available", true);
Run Code Online (Sandbox Code Playgroud)
编辑:
根据您对预订日期的评论,您应该为每个房间单独创建一个预订日历。然后只需在 Cloud Function 中创建一个可以使用 cron 作业触发的函数。此功能可以帮助您每天检查每个房间的可用性。如果房间可用,则将 设置available
为true
否则,将属性设置为false
并将房间从availabeRooms
集合中删除。
归档时间: |
|
查看次数: |
4946 次 |
最近记录: |