为了账号安全,请及时绑定邮箱和手机立即绑定

如何按降序对地图条目的键值进行排序?

如何按降序对地图条目的键值进行排序?

HUWWW 2022-12-15 16:33:19
我对 Java 比较陌生,使用比较器的整个排序让我有点困惑。是否可以在不使用比较器的情况下按降序对下面代码的当前输出进行排序?或者有没有更简单的方法让我理解如何对所述值进行排序。myRef.addChildEventListener(new ChildEventListener() {    @Override    public void onChildAdded(@NonNull DataSnapshot dataSnapshot , String s) {        Map<String, Object> userInfo = (Map<String, Object>)dataSnapshot.getValue();        String username = (String) userInfo.get("username");        Map<String, Long> steps = (Map<String, Long>) userInfo.get("steps");        long existingSteps = 0;        for (Map.Entry<String, Long> step : steps.entrySet()) {            existingSteps += Long.valueOf(step.getValue());        }        arrayList.add(new String( username + "  -  " + "steps:  " + existingSteps));        arrayAdapter = new ArrayAdapter<>(Leaderboard.this ,         android.R.layout.simple_list_item_1 , arrayList);        listView.setAdapter(arrayAdapter);}此代码的当前输出是:John Doe I - Steps: 79John Doe II - Steps: 111John Doe III - Steps: 0John Doe IV - Steps: 88John Doe V - Steps: 12John Doe VI - Steps: 0是否可以让此代码运行以下输出:John Doe II - Steps: 111John Doe IV - Steps: 88John Doe I - Steps: 79John Doe V - Steps: 12John Doe III - Steps: 0John Doe VI - Steps: 0数据库结构
查看完整描述

1 回答

?
动漫人物

TA贡献1815条经验 获得超10个赞

我能想到的最简单的解决方案是在每个用户对象下添加总步数作为新属性。在这种情况下,您还需要做一件事,即根据您每天获得的步数增加该属性。您的新架构应如下所示:


Firebase-root

  |

  --- user

       |

       --- userId

            |

            --- steps

            |    |

            |    --- //daily steps

            |

            --- target: 100

            |

            --- username: "John Doe I"

            |

            --- totalNumberOfSteps: 111

要根据totalNumberOfSteps属性按(升序)顺序排列用户,请使用以下代码行:


DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference();

DatabaseReference userRef = rootRef.child("user");

Query query = userRef.orderByChild("totalNumberOfSteps");

ValueEventListener valueEventListener = new ValueEventListener() {

    @Override

    public void onDataChange(DataSnapshot dataSnapshot) {

        for(DataSnapshot ds : dataSnapshot.getChildren()) {

            String username = ds.child("username").getValue(String.class);

            long totalNumberOfSteps = ds.child("totalNumberOfSteps").getValue(Long.class);

            Log.d(TAG, username + " - Steps: " + totalNumberOfSteps);

        }

    }


    @Override

    public void onCancelled(@NonNull DatabaseError databaseError) {

        Log.d(TAG, databaseError.getMessage()); //Don't ignore errors!

    }

};

query.addListenerForSingleValueEvent(valueEventListener);

然后按降序排列,请从以下帖子中查看我的回答:


如何按升序或降序排列firebase数据库数据?

最后,logcat 中的结果将是:


John Doe II - Steps: 111

John Doe IV - Steps: 88

John Doe I - Steps: 79

John Doe V - Steps: 12

John Doe III - Steps: 0

John Doe VI - Steps: 0


查看完整回答
反对 回复 2022-12-15
  • 1 回答
  • 0 关注
  • 114 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号