亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何按降序對地圖條目的鍵值進行排序?

如何按降序對地圖條目的鍵值進行排序?

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 關注
  • 98 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號