Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
0 / 0 / 0
Регистрация: 08.01.2020
Сообщений: 21

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

18.02.2023, 00:24. Показов 1747. Ответов 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
106 / 67 / 29
Регистрация: 22.04.2022
Сообщений: 232
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
106 / 67 / 29
Регистрация: 22.04.2022
Сообщений: 232
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
106 / 67 / 29
Регистрация: 22.04.2022
Сообщений: 232
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
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru