如果存在多个重复值,如何显示单个值?

时间:2016-07-09 16:22:26

标签: android firebase firebase-realtime-database firebaseui

我正在使用firebase数据库存储数据和firebase回收器适配器来显示数据。

RecyclerView recyclerView;
    static String SelectedCode;
    DatabaseReference root;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.content_get_data);

    Firebase.setAndroidContext(this);

    recyclerView=(RecyclerView)findViewById(R.id.recycler);
    recyclerView.setHasFixedSize(true);
    recyclerView.setLayoutManager(new LinearLayoutManager(this));

    root = FirebaseDatabase.getInstance().getReference();
    Query query = root.child("download").orderByChild("subjectCode");
    FirebaseRecyclerAdapter<CourseStorage, GetData.MessageViewHolder> adapter = new FirebaseRecyclerAdapter<CourseStorage, GetData.MessageViewHolder>(
            CourseStorage.class,
            android.R.layout.two_line_list_item,
            GetData.MessageViewHolder.class, query
    ) {
        @Override
        protected void populateViewHolder(MessageViewHolder viewHolder, final CourseStorage model, int position) {
            viewHolder.textView.setText(model.getSubjectCode());
        }
    };
    recyclerView.setAdapter(adapter);
}


public static class MessageViewHolder extends RecyclerView.ViewHolder{
    TextView textView;
    View mview;
    public MessageViewHolder(View itemView) {
        super(itemView);
        textView=(TextView)itemView.findViewById(android.R.id.text1);
        mview=itemView;

    }
}

CourseStorage类中的getSubjectCode函数是

 public String getSubjectCode () {
    return subjectCode;
}

我的数据库是 Database structure

我得到输出为 enter image description here

我不希望同一个subjectCode显示两次。我怎样才能实现它?

1 个答案:

答案 0 :(得分:1)

Firebase数据库查询语言中没有GROUP BY子句。与使用NoSQL数据库的情况一样,解决方案是以您的应用程序想要访问它的方式存储数据。

在您的情况下,由于您正在显示主题代码列表,因此我会在数据库中存储主题代码列表(除了您当前的数据)。例如:

latestItemKeyPerSubjectCode
  "COEG301": "-KM...38N"
  "COEG341": "-KM...vd-"
  ...

您存储的确切值实际上取决于您的需求。在这种情况下,我使用该主题代码存储了最新项目的密钥,但您也可以存储文件名(如果您希望在应用程序中显示该文件名),或者只是true如果您有不需要有意义的价值。