для которого есть несколько заданий и материалов к прочтению. Нужно выдавать материалы и задачи в четкой последовательности, например: материал 1 - задача 1 - задача 2 - материал 2. Учитывая условие с порядком, как лучше организовать?
1. В каждом материале/задаче сделать булевый ключ switch. При выводе списка проходимся по одному массиву материалов/задач, если у элемента switch true, то свичтим на массив второй сущности, и наоборот.
2. Сделать сущность Unit, которая в себе будет иметь айдишник задачи/материала и будет связана с уроком. В уроке же держим массив unitsOrder.
Либо какой-то еще вариант, если видите.
А при чем тут бизнес?) Выглядит как связь один урок ко многим заданиям, дальше эту связь реализуем в зависимости от контекста. Если вопрос про бд, то у материалов задач будет lesson_id. Можно сделать многие ко многим на будущее (вдруг материалы будут повторно использоваться), тогда в бд это промежуточная таблица с полями lesson_id, material_id, в эту же таблицу можем добавить поле для сортировки, например, order_id integer.
на Go я бы сделал yaml с описанием задач. Для задачи сделал бы поле What с её текстовой формулировкой для ученика, поле Name для идентификации задачи и поле, например, PrevExercises, в котором будет слайс имён задач, которые надо решить для решения данной задачи. При старте приложения я бы тупо анмаршалил этот yaml в мапу и для каждого ключа построил бы полное дерево всех задач: var map [string] Exercises type Exercise struct{ Name, What string PrevExercisesNames []string } Хранить это всё в sql бд на мой взгля оверкил и меганеудобно.
Обсуждают сегодня