- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设我正在尝试构建一个群组消息应用程序,因此我将数据库结构设计为如下所示:
users: {
uid1: { //A user id using push()
username: "user1"
email: "aaa@bbb.ccc"
timestampJoined: 18594659346
groups: {
gid1: true,
gid3: true
}
}
uid2: {
username: "user2"
email: "ddd@eee.fff"
timestampJoined: 34598263402
groups: {
gid1: true,
gid5: true
}
}
....
}
groups: {
gid1: { //A group id using push()
name: "group1"
users: {
uid1: true,
uid2: true
}
}
gid2: {
name: "group2"
users: {
uid5: true,
uid7: true,
uid80: true
}
}
...
}
messages: {
gid1: {
mid1: { //A message id using push()
sender: uid1
message: "hello"
timestamp: 12839617675
}
mid2: {
sender: uid2
message: "welcome"
timestamp: 39653027465
}
...
}
...
}
根据 Firebase 的文档,这会扩展得很好。
现在假设在我的应用程序中,我想在每条消息上显示发件人的用户名。
查询每条消息的用户名显然是不好的,因此我找到的解决方案之一是在每条消息中重复用户名。
消息节点现在看起来像这样:
messages: {
gid1: {
mid1: { //A message id using push()
sender: uid1
username: "user1"
message: "hello"
timestamp: 12839617675
}
mid2: {
sender: uid2
username: "user2"
message: "welcome"
timestamp: 39653027465
}
...
}
...
}
现在我想添加用户更改用户名的选项。
因此,如果用户决定更改其用户名,则必须在用户节点以及他发送的每条消息中进行更新。
如果我采用“监听每条消息”的方法,那么更改用户名就会很容易,因为我需要在一个位置更改名称。
现在,我还必须更新他发送的每个群组的每条消息中的名称。
我认为查询整个消息节点以获取用户 ID 是一个糟糕的设计,因此我考虑创建另一个节点来存储用户已发送的所有消息的位置。
它看起来像这样:
userMessages: {
uid1: {
gid1: {
mid1: true
}
gid3: {
mid6: true,
mid12: true
}
...
}
uid2: {
gid1: {
mid2: true
}
gid5: {
mid13: true,
mid25: true
}
...
}
...
}
现在我可以快速获取特定用户的所有消息的位置,并通过一次 updateChildren() 调用更新用户名。
这真的是最好的方法吗?我真的需要复制这么多数据(数百万条消息)只是因为我引用了动态值(用户名)吗?
或者在处理动态数据时有更好的方法吗?
最佳答案
这是一个完美的例子,说明了为什么一般来说,父节点名称(键)应该与它们包含或表示的值解除关联。
因此,一些大局思考可能会有所帮助,并且考虑用户体验可能会提供答案。
Now lets assume that inside my application, I want to display the sender's username on every message.
但是你真的想这么做吗?您的用户真的想要滚动浏览包含 10,000 条消息的列表吗?可能不会。最有可能的是,应用程序将显示这些消息的子集,甚至一次可能显示 10 或 12 条。
这里有一些想法:
假设有一个用户表:
users
uid_0
name: Charles
uid_1
name: Larry
uid_2:
name: Debbie
和消息表
messages
msg_1
sender: uid_1
message: "hello"
timestamp: 12839617675
observers:
uid_0: true
uid_1: true
uid_2: true
每个用户登录,应用程序执行一个查询,观察他们所属的消息节点 - 应用程序显示消息的消息文本以及也观察该消息的每个用户的名称(“组”) .
这也可以用于仅显示发布该内容的用户的用户名。
解决方案1:应用启动时,加载users节点中的所有用户,将它们存储在以uid_为键的字典中。
当消息节点被观察时,每条消息都会被加载,并且您将通过键将其他用户(或发布者)的 uid 存储在 users_dict 中,因此只需选择他们的名字即可:
let name = users_dict["uid_2"]
解决方案2:
假设您的用户节点中存储了大量数据(这是典型的情况)和一千个用户。当您感兴趣的只是他们的名字时,加载所有这些数据是没有意义的,因此您可以
a) 使用解决方案#1,忽略除 uid 和名称之外的所有其他数据或
b) 在 firebase 中创建一个单独的“names”节点,该节点仅保留用户名,因此您无需将其存储在 users 节点中。
names:
uid_0: Charles
uid_1: Larry
uid_2: Debbie
正如你所看到的,即使有几千个用户,加载的数据也很小。而且......这里很酷的事情是,如果你向名称节点添加一个监听器,如果用户更改了他们的命名应用程序将收到通知,并可以相应地更新您的 UI。
解决方案3:
根据需要加载您的姓名。虽然从技术上讲你可以这样做,但我不推荐这样做:
观察用户所属的所有消息节点。这些节点将被读入,并在读入时构建您需要名称的 uid 字典。然后根据uid对每个用户名进行查询。这可以工作,但您必须考虑 Firebase 的异步特性,并留出时间来加载名称。同样,您可以加载一条消息,然后使用以下路径加载该消息的用户名:users/uid_x/用户名。不过,这又会导致异步计时问题,即您将异步调用嵌套在异步调用或循环中,这可能应该避免。
任何解决方案的重点都是用户体验并保持 Firebase 结构尽可能扁平。
例如,如果您确实想要加载 10,000 条消息,请考虑将消息文本或主题分解到另一个节点中,并仅加载初始 UI 列表的这些节点。当用户深入查看消息时,然后加载其余数据。
关于Firebase 数据库 : Referencing a dynamic value,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37628453/
如何将多个json对象添加/映射到dart对象 import 'dart:async'; import 'dart:convert'; import 'package:flutter/foundati
我正在研究将产品集成到 Dynamics Great Plains 中。我之前使用过 Dynamics CRM,但没有使用过 Great Plains。我听说 GP 与 CRM 是不同的动物,即使它们
System.Linq.Dynamic.Core 和 System.Linq.Dynamic 有什么区别?我目前正在使用 System.Linq.Dynamic 并且它不包含对 的支持选择 和 多选
我正在尝试通过Firebase存储将图像上传到Firebase,然后在Firestore中创建一个文档,其中包含上述上传图像的网址。为此,我使用此功能 void uploadImageAndCr
我一直在尝试整理一些东西,使我可以从 ListPlot 中提取点,以便在进一步的计算中使用它们。我目前的方法是使用 Locator[] 选择点。这适用于显示点,但我无法弄清楚如何从带有 head Dy
只要我在与 Program 类相同的程序集中有类 ClassSameAssembly ,下面的代码就可以正常工作。但是,当我将类 ClassSameAssembly 移动到单独的程序集时,会引发 Ru
我只是尝试从Firebase实时数据库解析数据。 但在转换为模型时有问题 我正在尝试从Flutter上解析Firebase数据库中的数据。 但是一个错误说 MY Complete QUIZ: {-M5
我创建了一个方法,当我构建它时,出现了这个错误: type '_InternalLinkedHashMap' is not a subtype of type 'List' in type cast
我对这个 flutter 的简单图表代码有疑问。在我尝试运行代码时显示此错误。请任何人都可以帮助我在这.... The argument type 'List>' can't be assigned
我尝试在我的 flutter 应用程序中解析来自 Firestore 的文档。 Firestore 文档: 我创建了两个类来解析这个文档。 类产品: class Produkt{ String n
我有一个2d-List,其中包含一个字符串和一个Map,如下所示: List> content = [ [ "String", { "one": 23,
我使用 Dart“json_serializable”包在 Flutter 应用程序中的 Firestore 数据结构下反序列化。 { googleBookId: jjl4BgAAQBAJ, prov
我注册了 Dynamic CRM 在线试用版(30 天)并创建了一个非托管自定义解决方案(新字段、一些自定义实体等)。现在,我想导出非托管解决方案并将其导入到我的服务器中的 Dynamic CRM O
当我尝试从 StreamTransform 获取一些数据时遇到一些问题 我不明白什么是正确的数据类型 未捕获的异常:类型错误:“_StreamHandlerTransformer”的实例:“_Stre
我正在尝试获取用户数据,但在这样做时出现以下错误: Exception: type '_InternalLinkedHashMap' is not a subtype of type 'Map 我查看
我正在尝试在 sqflite 数据库中保存一些带有 flutter 的数据,但我仍然收到一条错误消息: [ERROR:flutter/shell/common/shell.cc(181)] Dart
我有一个JSON响应,结构如下:。在这个JSON响应中,有各种动态键,如“Owner”和“Master”,每个键都包含一个JSON对象或一个JSON对象数组。我需要创建一个gson数据类来解析这个动态
在 Dynamics 2012 ax 中编译 CIL 时,我看到以下错误 - 名称为“Dynamics.Ax.application”的重复类型。在程序集中“Dynamics.Ax.applicati
我有一个带有 LinkedHashMap 成员的 StatefulWidget 小部件,如下所示: LinkedHashMap _items = new LinkedHashMap>(); 现在我需要
我正在尝试按照此处所述实现搜索资源功能:https://cloudblogs.microsoft.com/dynamics365/it/2019/05/21/retrieve-resource-ava
我是一名优秀的程序员,十分优秀!