Ограничить запрос Firebase для одного дочернего узлаAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Ограничить запрос Firebase для одного дочернего узла

Сообщение Anonymous »

Из названия может показаться, что это бессмысленно, но я пытаюсь ограничить объем данных, получаемых из Firebase. У меня есть запрос, структурированный следующим образом:
for (final Map.Entry entry : map.entrySet())
{
final Query dataQuery = mFirebaseRef.child("someChild").child(entry.getKey());

dataQuery.addListenerForSingleValueEvent(new ValueEventListener()
{
// do something with data
}
}

Каждый возвращаемый дочерний элемент имеет метку времени. Теперь я хочу еще больше ограничить запрос, возвращая только дочерние элементы на карте, у которых метка времени новее, чем у предыдущего запроса.
Если я сформирую такой запрос:
final Query dataQuery = mFirebaseRef.child("someChild").orderByChild("timestamp").startAt(timeMsec);

Тогда это работает, и запрос возвращает всех дочерних элементов, соответствующих этим критериям.
Но я хочу сначала ограничиться только дочерними элементами на карте (используя . child(entry.getKey()), а затем проверьте значения меток времени, соответствующие этим критериям, т. е.
.for (final Map.Entry entry : map.entrySet())
{
final Query dataQuery = mFirebaseRef.child("someChild").child(entry.getKey()).orderByChild("timestamp").startAt(timeMsec);
...

И это не работает, даже если у детей есть отметка времени, соответствующая критериям. Это конкретное ограничение, согласно которому orderByChild не работает, когда запрос возвращает один дочерний элемент? Простая проверка — использовать timeMsec = 0, и запрос ничего не возвращает.
Вот json, начинающийся с "someChild":
"someChild": {
"6Pb5K88BiDOKOBlahBlahUID": {
"activeDays": 2,
"latest": 200,
"timestamp": 1713621397890,
"uid": "6Pb5K88BiDOKOBlahBlahUID",
},
"6pDVy45vzsgDYG7BlahBlahUID": {
"activeDays": 2,
"latest": 30,
"timestamp": 1712595611236,
"uid": "6pDVy45vzsgDYG7BBlahBlahUID",
},


Подробнее здесь: https://stackoverflow.com/questions/786 ... child-node
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»