0 / 0 / 0
Регистрация: 08.01.2020
Сообщений: 21

Реализация расписания в PostgreSql

18.02.2023, 00:24. Показов 1777. Ответов 6

Студворк — интернет-сервис помощи студентам
Вопрос в организации схемы БД для хранения расписания пользователей и студентов.
Пишется Web Api приложение на C# с использованием PostgreSql
Платформа для студентов и преподов, чтобы они могли назначать индивидуальные и групповые занятия

Основная суть в чем
Есть таблица преподаватель
У него есть расписание в котором он может указывать время когда он работает
Например: 18.02.2023 в 17:00-18:00 - индивидуальные занятия со студентов N
18.02.2023 в 14:00-15:00 групповые занятия со студентами
С 15:00 до 17:00 - свободное время в которое он может работать но нет студентов
И с 20:00 до 10:00 следующего дня - время когда он не работает

Как эффективнее хранить такую структуру в бд ?
С учетом того что преподаватель может по необходимости переносит время занятий и отменять их,
А если есть групповые занятия, то он сам определяет время и интервал занятий
Т.е. время занятия 18.02.2023 с 17:00 до 18:00 занятий будет 5
Повтор занятий каждые 3 дня

Среди коллег были предложены следующие варианты
1. Хранить даты как огромную строку в бд и парсить ее в дальнейшем
2. Хранить JSON файл в бд и также в дальнейшем парсить ее
3. Динамически создавать таблицы в бд для каждого преподавателя, чтобы корректно с ней работать и не захломлять таблицу другими данными (столбцы таблицы id, date_start, date_end) - это все datetime

Хотелось бы услышать критику данных вариантов
И если есть другие предложение по реализации - также было бы интересно почитать

Со всем уважением к пользователям данного форума
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.02.2023, 00:24
Ответы с готовыми решениями:

Реализация расписания
Необходимо реализовать механику расписания занятий факультета чтобы вдальнейшем можно было визуализировать с swing, ниже код который...

Реализация классов для расписания спортивных команд
Доброго всем времени. Помоги пожалуйста реализовать во такую штуку на php Реализовать объекты: команда (Team) 1. имеет...

Программно-алгоритмический реализация расписания функции в ряд Тейлора
Задания расчетно-графической работы «Программно-алгоритмический реализация расписания функции в ряд Тейлора» заключается в проведении...

6
107 / 68 / 29
Регистрация: 22.04.2022
Сообщений: 233
19.02.2023, 08:47
1,2 вообще не выдерживают никакой критики, 3 каким образом вы будете учитывать, что два преподавателя назначат занятия в одной аудитории одновременно? Вообщем всё в топку... таблица "расписание" должна быть одна и примерно такая
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
CREATE TABLE public.t_schedule (
    rec bigserial NOT NULL,  -- Идентификатор записи
    lecturer INTEGER NOT NULL, -- Идентификатор преподавателя
    room INTEGER NOT NULL, -- Идентификатор аудитории
    gro INTEGER NOT NULL, -- Идентификатор группы студентов
    tmr tsrange NOT NULL, -- Диапазон времени занятия
    rem text, -- Примечания
    CONSTRAINT t_schedule_pk PRIMARY KEY (rec),
    CONSTRAINT t_schedule_lecturer_excl EXCLUDE  -- Преподаватель не может вести да занятия одновременно
    USING gist(
      lecturer WITH pg_catalog.=?,
      tmr WITH pg_catalog.&&
    ),
    CONSTRAINT t_schedule_room_excl EXCLUDE  -- В одной аудитории не может быть двух занятий одновременно
    USING gist(
      room WITH pg_catalog.=?,
      tmr WITH pg_catalog.&&
    ),
    CONSTRAINT t_schedule_gro_excl EXCLUDE -- Одна группа студентов не может присутствовать на двух и более занятиях
    USING gist(
      gro WITH pg_catalog.=?,
      tmr WITH pg_catalog.&&
    )
);
ALTER TABLE public.t_schedule ENABLE ROW LEVEL SECURITY; -- Индивидуальный доступ к каждой записи таблицы
 
-- Добавляем политики доступа к записям таблицы
 
CREATE POLICY t_schedule_upol ON public.t_schedule
    AS PERMISSIVE
    FOR SELECT
    TO PUBLIC
    USING (TRUE);
 
-- И т.д.
Для создания такой таблицы понадобится создать расширение:
SQL
1
CREATE EXTENSION btree_gist WITH SCHEMA public;
См.
Ограничения для диапазонов
Создание политик
Политики защиты строк
1
0 / 0 / 0
Регистрация: 08.01.2020
Сообщений: 21
19.02.2023, 14:49  [ТС]
"3 каким образом вы будете учитывать, что два преподавателя назначат занятия в одной аудитории одновременно"

В данном функционале нет аудитории
Это приложение - просто связь студентов и преподов
Преподаватели - это репетиторы
Они сами указывают формат занятий
Индивидуальные, групповые, оффлайн, онлайн

А групповые занятия - в идеале
Назначается время, тип групповых занятий, количество и их интервал
Условно
Подготовка к ЕГЭ по математике
Время 19.02.2023 с 17:00 до 18:00
Кол-во занятий: 5
Интервал: каждые 3 дня

У меня создается 5 записей по расписанию
Но, в случае необходимости я могу менять конкретное занятие
Условно занятие 22.02.2023 я хочу передвинуть на час вперед с 18:00 до 19:00
0
107 / 68 / 29
Регистрация: 22.04.2022
Сообщений: 233
19.02.2023, 22:05
Я Вам предложил универсальное решение, Ваша задача допилить до того, что Вам нужно, например удалить поле room и добавить student... почитайте ссылки

Добавлено через 7 минут
Вся суть в том, что в таблице всегда будут корректные данные, т.е. Вы просто на сможете добавить пересекающиеся диапазоны времени, а передвигать / изменять/ добавлять записи в расписании этот задача приложения....
1
0 / 0 / 0
Регистрация: 08.01.2020
Сообщений: 21
19.02.2023, 22:53  [ТС]
Спасибо за помощь!
0
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 5
10.11.2023, 14:17
fte65,
Цитата Сообщение от fte65 Посмотреть сообщение
CONSTRAINT t_schedule_pk PRIMARY KEY (rec),
    CONSTRAINT t_schedule_lecturer_excl EXCLUDE  -- Преподаватель не может вести да занятия одновременно
    USING gist(
      lecturer WITH pg_catalog.=?,
      tmr WITH pg_catalog.&&
    ),
Здравствуйте! А можете ли подсказать как аналогичное написать на sql oracle ? Такое же задание сейчас выполняю, всю голову сломал.
0
107 / 68 / 29
Регистрация: 22.04.2022
Сообщений: 233
11.11.2023, 09:10
C Oracle, я не особо знаком, скорее всего это один в один не получится (в оракле нет gist индексов и типа данных range), поэтому можно решить задачу только с использованием триггеров.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.11.2023, 09:10
Помогаю со студенческими работами здесь

Программно-алгоритмический реализация расписания функции в ряд Тейлора
«Программно-алгоритмический реализация расписания функции в ряд Тейлора» заключается в проведении программной реализации расчета...

Реализация простого интерфейса для БД PostgreSQL
Нужно реализовать простой интерфейс на winforms c++/cli для бд postgres. Как поставить npgsql? как подключить его к проекту? Visual...

Реализация ИС "Составление расписания в школе"
Доброго времени суток, Уважаемые! У меня возник вопрос, каким оброзом можно реализовать ИС "Составление расписания в школе"....

Расписания
нужно сделать расписание в приложении он должен выглядеть как список я попробовал сделать через ListView но что то не очень))). ...

оставление расписания
Доброго времени суток всем!!!! Очень нужна помощь!!!! Дело вот в чем есть база данных в нее вносятся все данные об учебном процессе (фио...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru