0

作为 Firebase 中的数据结构,我需要一些帮助。我已经阅读了 API 指南和一些类似的博客文章:

  1. 查询,第 1 部分:为 Firebase 转换的常见 SQL 查询
  2. Firebase:现在有更多查询!
  3. 非规范化你的数据是正常的

我要离开 SQL(特别是 MySQL 和 SQLite)并尝试迁移到 Firebas。我想知道如何在 Firebase 中为结构化 JSON 构建这些表和关系。关系1-1;1 - N; N - N; 我正在发送包含一些关系的示例数据库的图片,你能给我这个支持吗?在你的数据库中看起来像这样吗?请记住,我需要查阅与 SQL 中的查询相同的数据。

这是我的数据库: 请忽略

4

1 回答 1

2

这个我就拍一下...

首先,Firebase 不是关系数据库,因此不应以这些术语来考虑它。但是,您可以在(对于最终用户)感觉“相关”的数据之间建立“关系”

让我们使用类似部门和员工的示例。一个部门可以有许多员工,这些员工属于该部门。

departments
  dept_00
    dept_name: "Bridge"
  dept_01
    dept_name: "Engineering"
  dept_02
    dept_name: "Medical"

crew
 crew_00
  crew_name: "Kirk"
  in_dept: "dept_00"
 crew_01
  crew_name: "Scotty"
  in_dept: "dept_01"
 crew_02
  crew_name: "Bones"
  in_dept: "dept_02"
 crew_04
  crew_name: "Spock"
  in_dept: "dept_00"

使用这种结构,可以对作为桥梁成员的工作人员执行查询:这是一个 ObjC 片段

Firebase *ref = [myRootRef childByAppendingPath:@"crew"];
FQuery *q1 = [ref queryOrderedByChild:@"in_dept"];
FQuery *q2 = [q1 queryEqualToValue:@"dept_00"];

[q2 observeEventType:FEventTypeChildAdded withBlock:^(FDataSnapshot *snapshot) {
  NSLog(@"%@", snapshot.value);
}];

这将返回 crowd_00 (Kirk) 和 crowd_04 (Spock) 节点。

请注意数据(Bridge、Engineering)和节点名称(dept_00、dept 01)之间的分离。这允许在不破坏它们之间的“链接”的情况下修改数据。所以我可以将“Engineering”重命名为“Scotty's Hideaway”,一切都会继续进行。这些“随机”节点名称将由 firebase 中的 push() 或 ChildByAutoId (objc) 生成

同样,如果我们知道机组成员的姓名(Bones),我们可以查询该特定节点以返回他属于 dept_02(医疗)。

如果 Spock 和 Bones 属于多个不同的部门,例如 Bridge 和 Engineering,则可以通过添加另一个节点来跟踪机组成员所属的部门,从而超越此范围:

belongs_to
  crew_02
   dept_00: true
   dept_02: true
  crew_04
   dept_00: true
   dept_01: true

在这里,crew_02(骨头)现在在医疗和桥梁部门(让 Spocks 很沮丧),而 cramp_04(Spock)现在在桥梁和工程部门。使用这个添加的belong_to 节点,可以从crew 节点中删除in_dept 子节点。

这应该涵盖一对一、一对多和多对多

于 2015-10-08T18:17:19.987 回答