Из названия может показаться, что это бессмысленно, но я пытаюсь ограничить объем данных, получаемых из 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
Ограничить запрос Firebase для одного дочернего узла ⇐ Android
Форум для тех, кто программирует под Android
-
Anonymous
1719353345
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",
},
Подробнее здесь: [url]https://stackoverflow.com/questions/78669640/limit-firebase-query-for-a-single-child-node[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия