Поиск на основе данных, сохраненных в firebase realtime

#android #firebase-realtime-database

#Android #firebase-база данных в реальном времени

Вопрос:

как я могу перечислить пользователей, которые вошли в систему в тот день? У меня есть поле в firebase, где сохраняются дата и время. но меня интересует фильтрация поиска на основе текущего дня на основе даты устройства с использованием данных, сохраненных в firebaserealtime? может кто-нибудь сказать мне, как я могу фильтровать, используя эти требования? заранее спасибо.

код для сохранения даты в базе данных.

   //DataDia
usuarioAtual = UsuarioFirebase.getUsuarioAtual();
final DatabaseReference firebaseRef = ConfiguracaoFirebase.getFirebaseDatabase();
DatabaseReference usuario = firebaseRef.child("usuarios").child(getIdentificadorUsuario() );
final String userId = user.getUid();
firebaseRef.child("usuarios").child(userId).addListenerForSingleValueEvent(new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        for (DataSnapshot ds : dataSnapshot.getChildren()) {



        }
        DateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
        Date date = new Date();
        String strDate = dateFormat.format(date).toString();
        firebaseRef.child("usuarios").child(getIdentificadorUsuario()).child("DataDia").setValue(strDate);


    }



    @Override
    public void onCancelled(DatabaseError databaseError) {

    }

});
  

код для поиска пользователей

 usuariosRef = ConfiguracaoFirebase.getFirebaseDatabase().child("usuarios");
  

структура базы данных

введите описание изображения здесь

Комментарии:

1. Если вы хотите фильтровать по дате, у вас должен быть дочерний элемент, содержащий только эту дату, не включая время.

2. Вы можете использовать System.timeInMiliis() для сохранения даты, а затем запросить ее

3. @DougStevenson ПРИВЕТ, спасибо за ваш ответ. Я изменен на гггг / ММ / дд imgur.com/a/jf4mnDj как реализовать этот фильтр? заранее спасибо.

4. Как вы видите в документации. firebase.google.com/docs/database/android /…

Ответ №1:

Чтобы получить всех пользователей на определенную дату, вам необходимо:

  1. Создайте строку с этой датой в том формате, в котором она хранится в базе данных.
  2. Затем запустите запрос с этой строкой к свойству.

Итак, что-то вроде:

 firebaseRef.child("usuarios") // Note that there's no .child(userId) here anymore
  .orderByChild("DataDia").equalTo("2020/10/15")
  .addListenerForSingleValueEvent(new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        for (DataSnapshot ds : dataSnapshot.getChildren()) {
            Log.i("DB", ds.getKey());
            Log.i("DB", ds.child("DataDia").getValue(String.class));
        }
    }
    ...
  

Ответ №2:

Я думаю, вы можете использовать equalTo из документации

 DateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd");
Date date = YOUR_INPUT_DATE;
String strDate = dateFormat.format(date).toString();
usuariosRef = ConfiguracaoFirebase.getFirebaseDatabase().child("usuarios");
Query q = usuariosRef.equalTo(strDate)