我正在开发一款应用,可帮助用户搜索图书并下载其他用户作为帖子形式上传的图书。
为了首先下载书籍,用户应该根据标题等属性进行搜索。
符合用户要求的帖子应显示在 firebase-UI 回收站视图中。
这是我的Firebase数据结构:
我想要创建查询的示例代码,该代码会返回方便帖子的ID,例如 ImgBRr2YFYfAu1WwENS1Ucj6jz13_1514813350760 。
请帮我解决问题,欢迎任何建议和想法
答案 0 :(得分:1)
这是你可以做的,
按语言搜索,然后按标题过滤&作者
public void search(String languangeSearchString, String title, String author){
FirebaseDatabase.getInstance().getReference().child("Posts").equalTo("language").startAt(languangeSearchString).addChildEventListener(new ChildEventListener() {
@Override
public void onChildAdded(DataSnapshot dataSnapshot, String s) {
String id = dataSnapshot.getKey();
if(dataSnapshot.child("title").exists() && dataSnapshot.child("author").exists()){
if(dataSnapshot.child("title").getValue(String.class).equals(title) && dataSnapshot.child("author").getValue(String.class).equals(author)){
//Here are the results
}
}
}
@Override
public void onChildChanged(DataSnapshot dataSnapshot, String s) {
}
@Override
public void onChildRemoved(DataSnapshot dataSnapshot) {
}
@Override
public void onChildMoved(DataSnapshot dataSnapshot, String s) {
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
答案 1 :(得分:0)
要在firebase-database
上进行搜索,我们通常使用orderBy()
。像
firebaseDatabase.getReference("Posts").child("postId")
.orderBy("authorId")
但它无法使用多个orderBy()
,
firebaseDatabase.getReference("Posts").child("postId")
.orderBy("authorId")
.orderBy("title") // this will throw an error
.orderBy("language")
所以你必须只在一个child-node
上进行搜索。
有关详细信息,请查看此Query based on multiple where clauses in Firebase