我正在尝试开发一个简单的应用程序来学习Firebase数据库。
这是我的实时数据库架构
mydirectory
-contact_list
-LOyDhepB_IZlM6lZtko
mobileNumber: "9385746982"
name: "Jay"
-LOyDhetiPHalLhXrOaU
mobileNumber: "8000478912"
name: "Ravi"
-LOyDhetiPHalLhXrOaV
mobileNumber: "123456789"
name: "ABC"
-LOyDheubruATyyBp8dG
mobileNumber: "023456879"
name: "XYZ"
我想获取按名称
排序的数据列表所以我正在使用此代码段将数据加载到我的android应用程序中
DatabaseReference mDatabase = FirebaseDatabase.getInstance().getReference();
mDatabase.child("contact_list").orderByChild("name").addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
Map<String, Object> objectMap = (HashMap<String, Object>) dataSnapshot.getValue();
Master.personList.clear();
for (Object obj : objectMap.values()) {
if (obj instanceof Map) {
Map<String, Object> mapObj = (Map<String, Object>) obj;
String name = (String) mapObj.get("name");
String mobileNumber = (String) mapObj.get("mobileNumber");
Person person = new Person(name, mobileNumber);
Master.personList.add(person);
populateListView();
}
}
}
@Override
public void onCancelled(DatabaseError error) {
// Failed to read value
Log.w("ANDs", "Failed to read value.", error.toException());
}
});
但是它不会根据
name
的字母顺序对数据进行排序 键。我是在做错什么还是错过了什么?
PS
我也索引了规则(ref),但结果仍然相同!它不能按字母顺序对数据进行排序。
{
"rules": {
"mydirectory": {
"contact_list": {
"$user_id": {
".indexOn": ["name"]
}
}
},
".read": true,
".write": true
}
}
我已经尝试了其他类似该主题的文章,但是没有任何效果!请不要使其重复,请帮助我解决它!
答案 0 :(得分:3)
HashMap
只能包含一个键和一个值。根据定义,Map
中的键是无序的。因此,当您致电dataSnapshot.getValue()
时,您将丢弃所有订购信息。
要维持顺序,您需要遍历dataSnapshot.getChildren()
:
public void onDataChange(DataSnapshot dataSnapshot) {
Master.personList.clear();
for (DataSnapshot contactSnapshot: dataSnapshot.getChildren()) {
String name = contactSnapshot.child("name").getValue(String.class);
String mobileNumber = contactSnapshot.child("mobileNumber").getValue(String.class);
Person person = new Person(name, mobileNumber);
Master.personList.add(person);
}
populateListView();
}
您还会注意到,我使用child(...)
获取特定属性的子快照并从中获取String
的值。您的方法也可以使用,但是我发现当我坚持使用更长的快照时(而不是转换为Map
),我会得到更好的错误消息。