Как получить сообщения за последние 24 часа, а затем отсортировать их по кликам, а затем по временным меткам? - PullRequest
0 голосов
/ 17 февраля 2020

Как запустить запрос, который извлекает только сообщения за последние 24 часа и сортирует их по кликам, а затем по временным меткам для тех сообщений, которые имеют одинаковое количество кликов?

Ссылка:

https://firebase.google.com/docs/firestore/query-data/order-limit-data

Это разрешено в документации, а не в результате, которого я хочу:

getRef = global.db.collection("AllSubmissions")
               .orderBy('timestamp', 'desc')
               .where("timestamp", ">", date24)
               .orderBy('clicks', 'desc')
               .startAfter(theDoc)
               .limit(limit);

Но это то, что я хотел бы получить :

getRef = global.db.collection("AllSubmissions")
               .orderBy('clicks', 'desc')
               .orderBy('timestamp', 'desc')
               .where("timestamp", ">", date24)
               .startAfter(theDoc)
               .limit(limit);

Для которого я получаю следующую ошибку (как также объясняется в документации):

Ошибка:

Ошибка: 3 INVALID_ARGUMENT: фильтр неравенства свойство и первый порядок сортировки должны быть одинаковыми: отметка времени и клики

Есть ли другой способ создания пропущенного запроса, или это действительно ограничение Firestore?

PS: у меня есть индексы, созданные для всех составных запросов.

1 Ответ

0 голосов
/ 19 февраля 2020

Извините за мой последний ответ, я понял, что я запускаю неправильный код. Как вы упомянули, при запуске кода

getRef = global.db.collection("AllSubmissions")
           .orderBy('clicks', 'desc')
           .orderBy('timestamp', 'desc')
           .where("timestamp", ">", date24)
           .startAfter(theDoc)
           .limit(limit);

появляется следующая ошибка

Ошибка: 3 INVALID_ARGUMENT: свойство фильтра неравенства и первый порядок сортировки должны совпадать: timestamp и щелкает

Для кода, которым я поделился:

getRef = global.db.collection("AllSubmissions")
       .orderBy('clicks', 'desc')
       .orderBy('timestamp', 'desc')
       .where("clicks", ">=", 0)
       .where("timestamp", ">", date24)
       .startAfter(theDoc)
       .limit(limit);

Вы получаете новую ошибку

Ошибка: 3 INVALID_ARGUMENT: Нельзя включить фильтры неравенства несколько свойств: [клики, отметка времени]

Как правило, эти ошибки являются частью ограничений запросов. Первая ошибка связана с this , в котором упоминается следующее:

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

, в то время как вторая ошибка может быть больше связана с this , в котором упоминается следующее:

Чтобы избежать сканирования всего индекса, запрос Механизм полагается на то, что все потенциальные результаты запроса соседствуют друг с другом в индексе. Чтобы удовлетворить это ограничение, один запрос не может использовать сравнения неравенства (LESS_THAN, LESS_THAN_OR_EQUAL, GREATER_THAN, GREATER_THAN_OR_EQUAL, NOT_EQUAL) для более чем одного свойства во всех его фильтрах.

Вы можете проверить другие ограничения на запросы, проверяющие этот документ .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...