Android FIrebase - FirebaseListAdapter的数据源

时间:2017-12-01 18:56:25

标签: android firebase-realtime-database

我的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) {

3 个答案:

答案 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个值,因此最佳做法是使用truefalse代替YN

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的特定用户的所有用户名。其次,我们只查询那些用户以显示他们的电子邮件地址。