繁体   English   中英

如何从具有相同字段(仅该特定字段的值)的 Firebase 实时数据库中检索值到 android 的文本视图中?

[英]How to retrieve values from a Firebase Realtime Database with same fields(only values of that particular field) into a text view in android?

这就是我的数据库的样子

我真正需要的是在TextView的“收入”字段中显示每个值。

250 105

这可能吗? 如果可能,请帮助我。

这就是我将值插入数据库的方式

private void addReport() {

    Float total_Income = Float.valueOf(tv_total_income.getText().toString());
    String current_date = tv_current_date.getText().toString();
    
    SimpleDateFormat sdf = new SimpleDateFormat("MMMM");
    String currentDateandTime = sdf.format(new Date());
    


    FirebaseDatabase mDatabase = FirebaseDatabase.getInstance();
    DatabaseReference mDbRef = mDatabase.getReference("Reports"+"/"+currentDateandTime+"/"+current_date).child("Date");
    mDbRef.setValue(current_date);
    DatabaseReference mDbRef1 = mDatabase.getReference("Reports"+"/"+currentDateandTime+"/"+current_date).child("Income");
    mDbRef1.setValue(total_Income);

}

虽然 Sairaj Sawant 的答案可能有效,但请记住,无需在循环的每次迭代中附加侦听器。 更方便的解决方案是只附加一次侦听器,如以下代码行所示:

DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference();
DatabaseReference juneRef = rootRef.child("Reports").child("June");
ValueEventListener valueEventListener = new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        String totalIncome = "";
        for(DataSnapshot ds : dataSnapshot.getChildren()) {
            totalIncome = totalIncome + ds.child("Income").getValue(String.class) + " ";
            
        }
        Log.d("TAG", totalIncome);
        textView.setText(totalIncome);
    }

    @Override
    public void onCancelled(@NonNull DatabaseError databaseError) {
        Log.d("TAG", databaseError.getMessage()); //Don't ignore errors!
    }
};
juneRef.addListenerForSingleValueEvent(valueEventListener);

此代码仅在Income属性为字符串类型时才有效,因为它是在您的20-06-2020孩子中设置的。 但是,如果将值设置为Integer ,则上述代码将不起作用,因为它在您的第二个21-06-2020孩子中设置。 请记住,两种类型的值都必须匹配。 您可以将两者都设置为 String 并且上面的代码将起作用,或者您将它们设置为数字,在这种情况下您应该使用此行:

totalIncome = totalIncome + ds.child("Income").getValue(Long.class) + " ";

尝试在Reports下访问June的孩子并循环获取income ,如下所示:

DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference();    
DatabaseReference reportsRef = rootRef.child("Reports").child("June");
ValueEventListener eventListener = new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        for (DataSnapshot ds : dataSnapshot.getChildren()) {
            String key = ds.getKey();
            DatabaseReference keyRef = rootRef.child(key).child("income");
            ValueEventListener valueEventListener = new ValueEventListener() {
                @Override
                public void onDataChange(DataSnapshot dataSnapshot) {
                    for (DataSnapshot ds1 : dataSnapshot.getChildren()) {
                        String income = ds1.getValue(String.class);
                        Log.d("TAG", income);
                    }
                }
                @Override
                public void onCancelled(DatabaseError databaseError) {}
            };
            keyRef.addListenerForSingleValueEvent(valueEventListener);
        }
    }
    @Override
    public void onCancelled(DatabaseError databaseError) {}
};
reportsRef.addListenerForSingleValueEvent(eventListener);

暂无
暂无

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

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