如何解决根据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");
数据库结构
解决方法
要获取特定日期的所有用户,您需要:
- 使用您存储在数据库中的格式构造具有该日期的字符串。
- 然后针对该属性运行带有该字符串的查询。
类似这样:
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));
}
}
...
,
我认为您可以使用documentation中的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)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。