Я создаю доску объявлений, используя Node.JS/MongoDB. После того, как список вакансий куплен пользователем, он добавляется в базу данных и, используя индекс TTL, удаляется через 30 дней. Мне интересно, есть ли способ изменить поле вместо удаления всего документа? Я спрашиваю, потому что хотел бы дать пользователю возможность «обновить» свой список после истечения срока действия. Как лучше всего подойти к этому?
Вы также можете просто добавить поле с именем «renewalDate», инициализировать его датой создания, а затем запросить элементы, у которых есть дата обновления, которая наступила менее чем через 30 дней. Затем, чтобы «обновить» список, вы просто устанавливаете дату обновления на более актуальную дату, чтобы она снова отображалась в запросе. Затем вы можете запускать периодическую задачу (раз в ночь), чтобы навсегда удалить все документы, которые настолько устарели, что они даже больше не подлежат обновлению.
@ jfriend00 Я думаю, это поможет. Я мог бы даже сохранить индекс TTL, чтобы стереть супер старые списки, которые больше не подлежат продлению. Спасибо!
Вы можете добавить поле с именем «renewalDate», инициализировать его датой создания, а затем запросить элементы, у которых есть дата обновления, которая меньше 30 дней назад, для элементов для отображения. Затем, чтобы «обновить» список, вы просто устанавливаете дату обновления на более актуальную дату, чтобы она снова отображалась в запросе.
Затем вы можете запускать периодическую задачу (раз в ночь или раз в неделю), чтобы безвозвратно удалить любые документы, которые достаточно устарели и больше не подлежат обновлению. Или вы можете использовать функцию TTL для управления этим.
Вы можете настроить периодическую задачу в своем приложении.