我的Firebase数据库结构如下
根
- 用户
-username1
-age:30
-email_address:xxx@yyy.com
-user_connections
-username2:N
- 用户名3:Y
--username4:N
-username2
-username3
-username4
到目前为止,我已经查询了所有用户,并将结果用作我的FirebaseListAdapter的数据源....但是,如果当前用户是“username1”,我只希望列表显示username3(因为username1有“user_connections”)孩子将用户名3显示为Y)。
我基本上想要查询其“user_connections”子项的值为Y的所有记录(用户)的数据集。 这是可能的还是我需要重构我的数据库?
任何帮助都会非常感激.....我是一个非常新的Android工作
以下是我的代码
databaseUser = FirebaseDatabase.getInstance().getReference("users");
//initialize list view
FirebaseListAdapter<User> fireAdapter = new FirebaseListAdapter<User>(
getActivity(),
User.class,
R.layout.listview_row_search,
databaseUser
) {
@Override
protected void populateView(View v, User model, int position) {
答案 0 :(得分:1)
如果我理解你的问题,你正试图根据某个条件(user_connections)查询你的用户,Y是肯定的,N是不是我猜。您想要显示某些用户并隐藏某些用户。
可能的解决方案
//in populate view
DatabaseReference ref=FirebaseDatabase.getInstance().getReference.child("users").child(currentuser).child(model.getUser_Connections);
ref.addValueEventListener(new ValueEventListener(){
onDatachange{
//here you check
for(DataSnapshot ds: datasnapshot.getChildren()){
if(ds.getKey.getValue().equals("Y")){
//this is the key you want to show
String userid_toshow=ds.getKey;
}
}
}
});
然后检查用户下的每个用户名是否等于((userid_toshow))
可能会显示或隐藏列表的布局。
答案 1 :(得分:1)
您的数据说明您希望表示多对多关系(用户之间)。这个post讨论了2个不同实体之间的多对多关系。在您的情况下,您在单个实体类型之间存在多对多的关系。尽管您展示的结构正确地表示了所有数据事实并且可以使其工作,但它不会像其他表示一样进行缩放。下面是可以很好地扩展并代表相同数据的firebase结构。
root
- users
-username1
-age : 30
-email_address : xxx@yyy.com
... other user data
-username2
... user data goes here
-username3
... user data goes here
-username4
... user data goes here
- usersRelationships
-username1
-username3: true
.. no need to represent false users
-username2
.. user2 relationships
-username3
.. user3 relationships
-username4
.. etc
答案 2 :(得分:1)
您的Firebase数据库结构几乎就在那里,但因为在Firebase中,一个重要的规则是让数据尽可能扁平化,我会使用非规范化重新命名。对于这个我重新命令,你会看到这个视频,Denormalization is normal with the Firebase Database。因此,在您的情况下,您需要将user_connections
节点移到用户节点之外。由于Firebase可以保留boolean
个值,因此最佳做法是使用true
和false
代替Y
和N
。
Firebase-root
|
--- userConnections
|
--- username1
|
--- username3: true
|
--- username4: true
在Firebase中,当我们在特定节点上附加侦听器时,将下载整个节点。因此,如果您只想显示用户的名称,那么您也在下载用户连接,在这种情况下这不是必需的。所以这是拥有这样的数据库结构的主要原因。
如果要从属于特定用户的所有用户获取数据,则需要对数据库进行两次查询,以及如何实现此目的:
DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference();
DatabaseReference userNameRef = rootRef.child("users").child("userName1");
ValueEventListener valueEventListener = new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for(DataSnapshot ds : dataSnapshot.getChildren()) {
String userName = ds.getKey();
DatabaseReference usersRef = rootRef.child("users").child(userName);
ValueEventListener eventListener = new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
String email_address = ds.child("email_address").getValue(String.class);
Log.d("TAG", email_address);
}
@Override
public void onCancelled(DatabaseError databaseError) {}
};
usersRef.addListenerForSingleValueEvent(eventListener);
}
}
@Override
public void onCancelled(DatabaseError databaseError) {}
};
userNameRef.addListenerForSingleValueEvent(valueEventListener);
使用此代码,首先获取属于名为userName1的特定用户的所有用户名。其次,我们只查询那些用户以显示他们的电子邮件地址。