170 похожих чатов

Всем привет, подскажите плз какую базу лучше выбрать для следующего

основного функционала. Преподаватель может создавать страницу в которой содержаться задания разных типов, текста/ответы заданий могут быть абсолютно разными на усмотрением преподавателя. Задания координально могут отличаться. Сразу взял SQL базу, но что-то сижу и не пойму как сделать общую структуру под настолько разные задания и вот подумал, может стоит MongoDB для подобного юзать, что думаете?

7 ответов

6 просмотров

постгресс с жсонби - лучшее из обоих миров

Надо сначала определить ограничения на эти задания, а дальше будет понятно, как из этого сделать схему данных. Вполне возможно, что можно будет даже без JSON обойтись

Артем-Ильченко Автор вопроса

дело в том что под разные типы заданий разные ограничения, к примеру. 1-е задание: Есть вопросы, есть заранее заготовленные ответы, нужно выбрать правильный ответ с помощью чекбокса. 2-й: имеется текст, есть пропуски в нём, нужно ввести вручную правильные слова, при этом есть заранее определённый пул ответов под каждый пропуск. И тут схемы координально разные или я не прав?

Любую

> И тут схемы координально разные или я не прав? Если они разные, это не значит, что нельзя использовать РБД. Если есть таблицы, это не значит, что задание должно быть обязательно полностью просто одной строчкой в таблице. Например, можно просто завести JSON поле с "динамическими параметрами" задания, если они не будут нужны на уровне запросов. А можно сделать отдельно таблицу с типами заданий, отдельно таблицу с разными значениями разных параметров заданий, а в таблице заданий просто указывать его тип. А вот как сделать удобно зависит уже от того, что такое задание, какие в нём могут быть данные (у любого типа), что с ним будут делать.

Артем-Ильченко Автор вопроса

хорошо, спасибо большое, у меня просто почему-то мозг отверг идею с json в РБД и пытался как-то таблицами по строчке всё попробовать решить

Можно и без JSON. Смотря какие требования. Например, если каждый тип задания, его параметры и всё прочее тоже хранится в БД, то проще генерировать для них интерфейс и добавлять новые типы заданий

Похожие вопросы

Обсуждают сегодня

Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
Вот еще криповенькая штука. uMain.pas(517,3) Warning: Case statement does not handle all possible cases И ЧО? 😂
Александр (Rouse_) Багель
15
.model small .stack 100h .data a db 'Hello, World!', '$' ; исходная строка b db 20 dup(?) ; строка b с запасом на максимальную длину .code main: ...
Алексей -man
3
вопрос, кого посмотреть в ютубе или где почитать про указатели чтобы раз и навсегда запомнить зачем они нужны и как правильно ими пользоваться? поделитесь хорошими ресурсами, ...
-
14
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
Редактор листа Excel, по сути двумерный массив ячеек. Ячейка - это экземпляр класса, у нее всякие свойства, методы. Проблема в том, что количество используемых строк и колоно...
Sergey Bodrov
2
Is there a digital way to cut the electricity from a usb in linux? It sounds weird, but it's exactly what I need to do. I tried to simulate the unplug/replug but is not the ...
Eduard Rivas
15
Решаемо? У тебя есть софт собирающийся без хинтов ворнингов?
Александр (Rouse_) Багель
9
Карта сайта