我正在尝试使用orderByChild()按照平均评分对餐厅进行排序,但没有通过按平均评分对餐厅进行归类来返回餐厅。
这是我的代码:
public void filterQuality(){
DatabaseReference mRatingDb = FirebaseDatabase.getInstance().getReference();
Query topQualityQuery = mRatingDb.orderByChild("Average");
topQualityQuery.addListenerForSingleValueEvent(new ValueEventListener()
{
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
Map <String, Double> topQualityMap = new HashMap<>();
List list = new ArrayList();
List list2 = new ArrayList();
for (DataSnapshot ds: dataSnapshot.getChildren()){
topQualityMap.put(ds.getKey(), ds.child("Quality").child("Average").getValue(double.class));
list.add(ds.child("Quality").child("Average").getValue(double.class));
list2.add(ds.getKey());
Log.d("Top Quality", "Value" + topQualityMap);
Log.d("Top Quality", "Value" + list);
Log.d("Top Quality", "Value" + list2);
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
}
});
}
这是我从地图和清单中得到的信息,这些都是我尝试调试的:
值[3.0]
价值[茱莉斯纽卡斯尔旅馆]
值{Malmaison Newcastle = 2.0,Jurys Inn Newcastle = 3.0}
D /最高质量:值[3.0,2.0]
D /最高质量:价值[Jurys Inn Newcastle,Malmaison Newcastle]
D / Top质量:价值{Malmaison Newcastle = 2.0,Jurys Inn Newcastle = 3.0,The County Hotel,Newcastle = 4.0}
值[3.0,2.0,4.0]
价值[Jurys Inn Newcastle,Malmaison Newcastle,The County Hotel,纽卡斯尔]
这是我的基地:
如果有人知道为什么这不能正常工作,请提供帮助。 谢谢。
答案 0 :(得分:1)
您需要指定要订购的值的完整路径。
所以:
DatabaseReference mRatingDb = FirebaseDatabase.getInstance().getReference();
Query topQualityQuery = mRatingDb.orderByChild("Quality/Average");
topQualityQuery.addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
for (DataSnapshot ds: dataSnapshot.getChildren()){
Log.i("Firebase", ds.getKey()+": "+ ds.child("Quality/Average").getValue(double.class));
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
throw databaseError.toException(); // NEVER ignore errors
}
});