繁体   English   中英

Firebase Firestore fetch or Query with different field android

[英]Firebase Firestore fetch Or Query with different field android

如何获取不同字段的文档值? 例如,我有一个带有 Message 的数据库,我将所有聊天数据存储在这个集合中。现在我想获取两个用户之间的所有聊天数据,按时间戳排序。
据我从这里知道,firebase 也引入in运算符,但它是针对单个字段的
Firestore 快照
在此处输入图像描述

代码片段

db.collection("Message")
                .whereEqualTo("from",mAuth.getCurrentUser().getUid()) //to is receiver UID
                .whereEqualTo("to",to)
                 ||    // Or "I need or in between" 
                .whereEqualTo("to",mAuth.getCurrentUser().getUid())
                .whereEqualTo("from",to)
                .orderBy("time_stamp", Query.Direction.ASCENDING).... 

简而言之,我需要在两个字段条件之间或两者之间获取数据库。
预期 output
从firestore中获取登录用户和接收者之间的所有文档。(获取来自已登录和接收者ID或来自接收者和登录用户的数据)。

我是初学者,请帮助我解决此问题,否则任何解决方法都可以。 谢谢

首先获取所有具有"from"==mAuth.getCurrentUser().getUid的文档,然后过滤掉具有"to"==to的文档。 这是代码:

db.collection("Message")
                .whereEqualTo("from",mAuth.getCurrentUser().getUid)
                .orderBy("time_stamp", Query.Direction.ASCENDING)
                .get()
                .addOnSuccessListener(new OnSuccessListener<QuerySnapshot>() {
                    @Override
                    public void onSuccess(QuerySnapshot queryDocumentSnapshots) {
                        List<DocumentSnapshot> allDocs = queryDocumentSnapshots.getDocuments();
                        List<DocumentSnapshot> requiredList = new ArrayList<>();
                        for(DocumentSnapshot d : allDocs){
                            if(/*Cast into required type.I'm assuming string*/((String)d.get("to")).equalsIgnoreCase(to)){
                                requiredList.add(d);
                            }
                        }
                        // requiredList contains the required documents
                        // do whatever you want here...
                    }
                });

如有必要,索引数据库。 您可以检查任何所需索引的日志。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM