使用限制查询Firebase数据库

时间:2018-05-21 09:36:10

标签: android firebase firebase-realtime-database

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

我有这样的节点。

enter image description here

目前,我这样写了,它会返回我的所有消息。如果我有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) {

        }
    });
}

2 个答案:

答案 0 :(得分:2)

  

请尝试将limitToLast(int值)与您的查询一起使用

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

或者您可以使用timeStamp对其进行排序,例如

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

答案 1 :(得分:0)

或者你可以像这样轻松地将它们放入火炉

firebase.firestore().collection('messages').limit(100).get()