使用Firebase Java API检索/格式化数据的最佳方法

Mas*_*ike 8 java cloud mobile android firebase

我正在Firebase用于Android项目上的数据存储,并使用它Firebase Java API来处理数据.我不确定我是否尽可能高效地进行此操作,并且我想要一些关于检索和格式化数据的最佳实践的建议.我的Firebase存储库看起来像这样....

-POLLS
    NUMPOLLS - 5
    (pollskey) - NAME - Poll1
            NUMELECTIONS - 2
            ELECTIONS 
                (electionskey) - NAME - Election1
                        NUMNOMINATIONS - 2
                        NUMVOTERS - 2
                        NUMBERTOELECT - 1
                        VOTERS - (votesrkey) - NAME - Charles
                                         NUMBER - (678) 333-4444
                                 .
                                 .
                                 .
                                 (voterskey) - ...
                        NOMINATIONS - (nominationskey) - NAME - Richard Nixon
                                              NUMBEROFVOTES - 2
                                       .
                                       .
                                       .
                                      (nominationskey) - ...
            .
            .
            .
            (electionskey) - ...
     .
     .
     .
     (pollskey) - ...
Run Code Online (Sandbox Code Playgroud)

所以,例如在这里,我试图从民意调查中获取所有数据,以列出民意调查名称,选举名称,候选人姓名和每次选举的投票数.我DataSnapshotOnCreate()主要活动的功能期间得到了POLLS等级,如下所示...

private static final Firebase polls = pollsFirebase.child("Polls");
protected void onCreate(Bundle savedInstanceState) {

        polls.addListenerForSingleValueEvent(new ValueEventListener() {

            @Override
            public void onDataChange(DataSnapshot snapshot) {
                for (DataSnapshot child : snapshot.getChildren()) {
                    if (!child.getName().equals("NumPolls")) {
                        createPollTableAndHeaders(child);
                    }
                }

            }
        });
    }
Run Code Online (Sandbox Code Playgroud)

然后,我继续读出的数据的各个部分,我需要依次调用getValue()DataSnapshots,并检查由此而来的钥匙HashMaps......

private void createPollTableAndHeaders(DataSnapshot poll) {
    String pollName = "";
    int numPolls;
    Object p = poll.getValue();
    if (p instanceof HashMap) {
        HashMap pollHash = (HashMap) p;
        if (pollHash.containsKey("Name")) {
            pollName = (String) pollHash.get("Name");
        } 
        if (pollHash.containsKey("Elections")) {
            HashMap election = (HashMap) pollHash.get("Elections");
            Iterator electionIterator = election.values().iterator();
            while (electionIterator.hasNext()) {
                Object electionObj = electionIterator.next();
                if (electionObj instanceof HashMap) {
                    HashMap electionHash = (HashMap) electionObj;
                    if (electionHash.containsKey("Name")) {
                        String electionName = (String) electionHash.get("Name");
                    }
                }
            };
        }
    }
Run Code Online (Sandbox Code Playgroud)

这似乎是深入研究数据结构的一种非常繁琐的方式,我想知道是否有更好的方法.

我已经getValue(java.lang.Class<T> valueType)在文档中看到了这个方法,但由于我正在处理组合对象而不仅仅是原始类型的容器,因此无法让它在我的情况下工作.函数如何知道Firebase要分配给模型对象的哪些成员变量的数据?它是否将Firebase键名与成员变量匹配,因此这些必须完全相同,区分大小写?如何处理Firebase生成的关键名称,如推送到List?如何为组合对象构造模型对象?

Gre*_*tis 18

getValue(java.lang.Class valueType)方法遵循与jackson对象映射库相同的规则(我们在内部使用它:http://wiki.fasterxml.com/JacksonInFiveMinutes).因此,您的Java类必须具有默认构造函数(无参数)和要分配的属性的getter(https://www.firebase.com/docs/java-api/javadoc/com/firebase/client/DataSnapshot.html #getValue(java.lang.Class)).简而言之,是的,Firebase中的键名必须与成员变量匹配.

有关使用复合对象(包括列表)的示例,请参阅AndroidDrawing.具体来说,Segment该类包含Point实例列表.使用该.push()方法生成的数据列表有一个捕获.由于生成的密钥名称是字符串,因此它们在客户端中可以是唯一的,因此它们反序列化Maps而不是Lists.但是,如果您迭代,dataSnapshot.getChildren()它们将按顺序返回.

此外,如果您不想反序列化为HashMap,则可以在DataSnapshot上使用child()方法.例如:


String pollName = poll.child("Name").getValue(String.class); 
DataSnapshot elections = poll.child("Elections");
for (DataSnapshot election : elections.getChildren()) {
    String electionName = election.child("Name").getValue(String.class);
}

在此示例中,任何不存在的值都将返回为null.

希望有所帮助!