Squeak.ru - шаблоны программирования

почему второй запрос хранилища данных Google возвращает измененный экземпляр (без вызова put после первого запроса)?

Я столкнулся с очень нелогичной ситуацией с запросом хранилища данных.

вот шаги:

  1. получить объект с первым запросом: list_objects = MyModel.query(cls.name == name).fetch()

  2. изменить list_objects: for o in list_objects: o.value = new_value

  3. получить объект во второй раз: list_objects_2 = MyModel.query(cls.name == name).fetch()

  4. теперь все все объекты в list_objects_2 имеют новое_значение, хотя на шаге 2 никогда не вызывался метод put для фактического изменения хранилища данных, и я проверил свое хранилище данных между ними, и значение является исходным значением.

  5. изменить list_objects_2: for o in list_objects_2: o.value = new_new_value, и теперь все list_objects1 имеют new_new_value

Я также пробовал с fetch(keys_only = True) и k.get(), но та же проблема.

у меня сложилось впечатление, что запрос относится к фактическому хранилищу данных, почему он продолжает возвращать одни и те же экземпляры вместо создания новых? это из-за кэширования какой-то?


  • Звучит не так, можете ли вы привести воспроизводимый пример? 23.06.2016

Ответы:


1

Ознакомьтесь с этой статьей https://cloud.google.com/appengine/docs/python/ndb/cache

Кэш в контексте работает быстро; этот кеш живет в памяти. Когда функция NDB записывает в хранилище данных, она также записывает в контекстный кэш. Когда функция NDB считывает сущность, она сначала проверяет контекстный кеш. Если сущность найдена там, взаимодействия с хранилищем данных не происходит.

Когда функция NDB запрашивает хранилище данных, список результатов извлекается из хранилища данных. Однако если какой-либо отдельный результат находится в контекстном кэше, он используется вместо значения, полученного из запроса к хранилищу данных. Результаты запроса записываются обратно в контекстный кеш, если так указано в политике кеша (но не в Memcache).

1) list_objects = MyModel.query(cls.name == name).fetch()

разогревает контекстный кеш

2) for o in list_objects: o.value = new_value

изменяет объекты только в памяти

3) list_objects_2 = MyModel.query(cls.name == name).fetch()

на самом деле никакого взаимодействия с хранилищем данных не происходит, вы получаете те же объекты из кеша

4) for o in list_objects_2: o.value = new_new_value

изменяет объекты только в памяти

5) fetch(keys_only = True) и k.get() взаимодействие с хранилищем данных не происходит

23.06.2016
  • Спасибо! В этом случае. Я понял это после проб и ошибок, это связано с кешированием в процессе, если я добавляю fetch(use_cache=False), то запрос возвращает новые экземпляры, хотя я немного удивлен, почему кеширование в процессе включено по умолчанию. 23.06.2016
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...