当前位置: 首页 > 知识库问答 >
问题:

Firestore-DocumentSnapshot和QueryDocumentSnapshot之间的区别

琴镜
2023-03-14

文件上说

QueryDocumentSnapshot包含作为查询的一部分从Firest数据库中的文档中读取的数据。该文档保证存在,并且可以使用getData()或get()方法提取其数据。

QueryDocumentSnapshot提供与DocumentSnapshot相同的API曲面。由于查询结果仅包含现有文档,因此存在()方法将始终返回true并且getData()永远不会为空。

https://firebase.google.com/docs/reference/android/com/google/firebase/firestore/QueryDocumentSnapshot

但这并不能解释我什么时候应该用一个来代替另一个。我在一个集合的SnapshotListener中尝试了这两种方法,都奏效了。

protected void onStart() {
    super.onStart();
    notebookRef.addSnapshotListener(new EventListener<QuerySnapshot>() {
        @Override
        public void onEvent(QuerySnapshot queryDocumentSnapshots, FirebaseFirestoreException e) {
            if (e != null) {
                Toast.makeText(MainActivity.this, "Error while loading!", Toast.LENGTH_SHORT).show();
                Log.d(TAG, e.toString());
                return;
            }

            String allNotes = "";

            for (QueryDocumentSnapshot documentSnapshot : queryDocumentSnapshots) {


                Note note = documentSnapshot.toObject(Note.class);

                String title = note.getTitle();
                String description = note.getDescription();

                allNotes += "\nTitle: " + title + " Description: " + description;

            }

            textViewData.setText(allNotes);
        }
    });
}

共有1个答案

赵昊阳
2023-03-14

正如你所说:

QueryDocumentSnapshot提供与DocumentSnapshot相同的API表面

这是因为QueryDocumentSnapshot是DocumentSnapshot的子类。这意味着每个QueryDocumentSnapshot都可以分配(向下转换)给DocumentSnapshot类型的变量。它们做完全相同的事情,除了您声明的它们之间的区别:

由于查询结果只包含现有文档,exists()方法将始终返回true,getData()永远不会为null。

因此,如果您正在处理QueryDocumentSnapshot,那么可以保证exists()方法将返回什么。如果您处理的是DocumenSnapshot(实际上不是一个被降级的QueryDocumentSnapshot),那么您就没有这个保证。

我想你可能太看重一个是另一个的子类这一事实了。只需使用您在API文档中看到的类型,不要将任何内容强制转换为其他类型,除非您确实知道需要这样做。

 类似资料:
  • 问题内容: 我错放了太多次了,我想我一直忘记,因为我不知道两者之间的区别,只是一个给了我我期望的价值,而另一个却没有。 为什么是这样? 问题答案: 是的简写形式(尽管请注意,该表达式只会被计算一次。) 是的,即指定一元的到。 例子:

  • 问题内容: 因此,我有一段简单的代码可以打印出整数1-10: 然后,如果仅在第3行上更改一个运算符,它将打印出无限数量的1整数(我知道为什么会这样做)。为什么在运行第二个程序时没有出现语法错误?如果赋值运算符后面跟着一个加法运算符,它不会调用语法错误吗? 问题答案: 与相同, 只是意味着。

  • 问题内容: 有人可以解释一下 和 我不知道“确切”的含义 问题答案: 在这个例子中,什么都没有。当您具有多个具有相似名称的路径时,该参数将起作用: 例如,假设我们有一个显示用户列表的组件。我们还有一个用于创建用户的组件。的网址应嵌套在下。因此,我们的设置可能如下所示: 现在,这里的问题是,当我们转到路由器时,将通过所有定义的路由,并返回它找到的第一个匹配项。因此,在这种情况下,它将首先找到路线,然

  • 问题内容: 我很好奇printStackTrace()和toString()之间的区别是什么。乍一看,他们 似乎 做的完全相同。 码: 问题答案: 不,有重要区别!使用toString,您只有异常的类型和错误消息。使用printStackTrace()可以获得异常的整个堆栈跟踪,这对于调试非常有帮助。 System.out.println(toString())的示例: printStackTra

  • 问题内容: 我看不到两种方式之间的任何区别,@ Qualifier 始终与 @Autowired一起使用 。 VS 有人能让我知道其中的区别吗?谢谢! 问题答案: 可以单独使用。如果单独使用,将按类型进行接线。因此,如果在容器中声明了多个相同类型的bean,而又不知道要注入哪个bean,就会出现问题。结果,通过指定Bean名称(按名称进行绑定),与一起使用来阐明要实际连接的Bean 也按名称接线。