Arhn - архитектура программирования

Хранилище данных GAE, как опрашивать новые элементы

Я использую python, ndb и хранилище данных. Моя модель ("Событие") имеет свойство:

created = ndb.DateTimeProperty(auto_now_add=True).

События время от времени сохраняются, иногда по несколько в течение одной секунды.

Я хочу «опросить новые события», не получая одно и то же событие дважды, и получить пустой результат, если новых событий нет. Однако повторный опрос может дать мне новые события.

Я видел курсоры, но не знаю, их можно как-то использовать для опроса новых событий после достижения конца первого запроса? «next_cursor» имеет значение None, когда я достиг (текущего) конца данных.

Сохранение последнего полученного «созданного» свойства DateTime и использование его для получения следующей партии работ, но это только использование разрешения в секундах, поэтому порядок может быть испорчен.

Должен ли я создать для этого свой собственный транзакционный счетчик в Event?


Ответы:


1

Да, использование курсоров является допустимым вариантом. Хотя эта ссылка взята из документации по Java, она также действительна для python. Второй абзац - это то, что вы ищете:

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

30.01.2015
  • Точно такой же документ доступен и для Python: cloud.google.com. /appengine/docs/python/хранилище данных/ 30.01.2015

  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..


    © 2024 arhn.ru, Arhn - архитектура программирования