android - 使用限制查询 Firebase 数据库

我刚刚开始使用 firebase,它非常有用。

我有这样的节点。

目前,我是这样写的,它会返回我所有的消息。如果我有 1k 条消息,它会返回 1k 条消息。我只想查询最新的 100 条消息。是否可以?我需要编写云功能吗?

private void retrieveConversation(String conversationID) {

    Query queryRoom = FirebaseDatabase.getInstance().getReference().child("Conversation").child(conversationID);
    queryRoom.keepSynced(true);
    queryRoom.addValueEventListener(new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {
            Conversation conversation = dataSnapshot.getValue(Conversation.class);
            if (conversation != null) {
                conversation = updateConversation(conversation);
                mainMessage.conversations.put(conversation.getId(), conversation);
                EventBus.getDefault().post(new ChatAdapter.AddMessage());
            }
        }

        @Override
        public void onCancelled(DatabaseError databaseError) {

        }
    });
}

最佳答案

Please try using limitToLast(int value) along with your query

Query queryRoom = FirebaseDatabase.getInstance().getReference().child("Conversation").child(conversationID).limitToLast(100);

Or you can sort them by using timeStamp like

FirebaseDatabase.getInstance().getReference()
.child("Conversation").child(conversationID)
.limitToLast(100)
.orderByChild("timestamp")
.startAt(dateToStart)    // pass timestamp from when you want to start filtering
.endAt(dateToEnd); // pass timestamp till when you want to apply filtering

https://stackoverflow.com/questions/50445865/

相关文章:

ruby-on-rails - 提交 Rails 的 credentials.yml.enc 文件是

python - 自定义转换器和 GridSearch - 管道中的 ValueError

intellij-idea - IntelliJ IDEA - 在路径中查找被锁定在另一个窗口监视器

wordpress - 使用 AWS RDS 和我自己的数据库哪个最便宜?

ansible - 例如,如何限制 Ansible 的设置模块 (gather_facts) 仅检索

python - 如何永远运行异步函数(Python)

java - Spring boot ConditionalOnBean 注解

regex - 为什么我不能在 clojure 中的 "|"拆分

python-3.x - 使用 xarray 计算月平均值

python - 使用 bigquery tables GET api 获取表的最后修改日期