Javascript-форум (https://javascript.ru/forum/)
-   Node.JS (https://javascript.ru/forum/node-js-io-js/)
-   -   Mongoose схемы вопросы организации (https://javascript.ru/forum/node-js-io-js/80284-mongoose-skhemy-voprosy-organizacii.html)

illusion 18.05.2020 05:57

Mongoose схемы вопросы организации
 
Возможно все намного проще сделать чем я думаю.
Пишу приложение для обучения, возможно пригодиться кому-либо.
Подсчет расходов/доходов
Использую Node js, Mongoose
Названия категорий расходов- categories
const costsSchema = new Schema( 
      {
      costs: {
        categories: [{
          name: {
          type: [String],
          minlength:[1,"Вы не ввели имя категории"],
          maxlength:[40,"Слишком длинное имя категории"],
          unique: true,
          default: ["Жилье","Коммунальны услуги","Продукты","Проезд","Интернет",
          "Сотовая связь","Одежда","Медикаменты","Хозяйственные расходы","Покупка техники",
          "Развлечения и отдых","Подарки к дню рождения","Прочее"]
        },
        color:{
          type: [String],
          default:["green","green","green","green","green","green","green","green","green",
          "green","green","green","green"]
        }
        }],
        days: [{
          date: Date,
          arrEvents: [{
            categoriesDay: Number
          }]
        }]

    }
  })


Размер массива days может достигать 365 в год и в каждом дне номер соответствующий данным в cost.categories
Например в days.arrEvents[0]. categoriesDay = 2 означает категория "Продукты" и цвет "red"
В процессе работы могут меняться названия категорий, удаляться появляться новые, меняться цвет.
Допустим есть данные за пару лет, тогда при, например, удалении одной из категорий изменится индекс и необходимо менять значения days.arrEvents[0]. categoriesDay
В каждом дне за эти 2 года.
Вариант решения:
Ввести промежуточную сущность, которая будет записывать изменение.
- при этом не нужно будет менять все дни
-Но размер данных сущности будет расти с каждым изменением категорий
Отдельный процесс по расписанию или по анализу загруженности сервера производит перезапись всех дней и обнуляет данные промежуточной сущности.


1. Есть ли решение по проще?
2. Еще если все делать по принципу разделяй и властвуй и для лучшего понимания кода другими разработчиками, то вместо моей одной большой (показано только часть схемы) разбить схему используя вложенные схемы?
3. Моя тема относится к категории антипаттерна преждевременной оптимизации?


Часовой пояс GMT +3, время: 17:00.