|
2 / 2 / 0
Регистрация: 26.05.2020
Сообщений: 331
|
|
Как сделать проверку на добавление записи в БД13.05.2021, 14:29. Показов 5827. Ответов 42
Метки нет (Все метки)
У меня есть таблица расписание (raspisanie) куда я добавляю запись о каком-либо занятий группы. И мне нужно как-то сделать проверку на то, чтобы один преподаватель не мог вести в одинаковое время 2 пары. И ещё, чтобы нельзя было добавлять занятие для группы, если например у этой группы уже есть занятие в это время. Время получается из (id_day(это день недели) и id_para(это время пары)). Преподаватель может преподавать несколько дисциплин, и он указан в таблице discipline_academic как id_teacher. Помогите пожалуйста.
0
|
|
| 13.05.2021, 14:29 | |
|
Ответы с готовыми решениями:
42
Как сделать проверку на свободное время для записи в Yii2? Как сделать добавление записи через ADOTable?
|
|
112 / 110 / 30
Регистрация: 08.05.2021
Сообщений: 485
|
||
| 14.05.2021, 08:59 | ||
|
0
|
||
|
800 / 583 / 207
Регистрация: 21.02.2019
Сообщений: 2,095
|
|
| 14.05.2021, 10:36 | |
|
... а если доцент Первозванный залогинился, но отошел налить чашку кофе, а в это время ассистент Молодаядаранняя успела перехватить пару - индекс поможет?
0
|
|
|
14330 / 9423 / 1356
Регистрация: 21.01.2016
Сообщений: 35,517
|
|
| 14.05.2021, 11:31 | |
|
mashmed135, не объективный это факт, а просто мнение ваше личное. Точно так же индекс и в MS SQL навешивается и в MySQL и в Firebird.
А что объективно так это то, что ТС, судя по всему, ни в зуб ногой, чтобы вообще хоть какой-то совет понять. Но выкладывать ему примеры для Postgres, когда он работает с MS SQL Server это, конечно, вообще классное решение.
0
|
|
|
112 / 110 / 30
Регистрация: 08.05.2021
Сообщений: 485
|
||||
| 14.05.2021, 11:43 | ||||
|
0
|
||||
|
2 / 2 / 0
Регистрация: 26.05.2020
Сообщений: 331
|
|
| 14.05.2021, 11:45 [ТС] | |
|
Usaga, В том то и дело, что не могу. Я за этим запросом и пришёл
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|
| 14.05.2021, 12:13 | |
|
danhiroman, Вы так и не ответили на вопрос, через какие инструменты Вы работаете с базой.
Вы код можете свой привести ?
0
|
|
|
2 / 2 / 0
Регистрация: 26.05.2020
Сообщений: 331
|
|
| 14.05.2021, 12:19 [ТС] | |
|
MsGuns, Добавляю данные в базу, изменяю их и удаляю с помощью LINQ2SQL
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|
| 14.05.2021, 12:24 | |
|
0
|
|
|
2 / 2 / 0
Регистрация: 26.05.2020
Сообщений: 331
|
||||||
| 14.05.2021, 12:26 [ТС] | ||||||
|
MsGuns, Вот пример добавления записи в БД.
0
|
||||||
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
||||||
| 14.05.2021, 12:48 | ||||||
0
|
||||||
|
2 / 2 / 0
Регистрация: 26.05.2020
Сообщений: 331
|
|
| 14.05.2021, 13:16 [ТС] | |
|
MsGuns, Это всё конечно хорошо. Но проблема собственно заключается в написание выражения для выборки. Информация о группах и учителе не содержится напрямую в Raspisanie. Там содержится только поле id_discipline, которое вводит пользователь и в котором как раз хранятся id_teacher и id_group. Получается что мне нужно. Мне надо получить значения id_teacher и id_group на основе выбранной пользователем дисциплины из Combobox, и потом сравнить их с теми полями в БД (при этом при сравнении нужно постоянно, получать из id_discipline значения соответствующих id_group и id_teacher.), в которых id_day и id_para совпадают с введёнными в соответствующих combobox. Но как это записать программно я незнаю.
0
|
|
|
|
|
| 14.05.2021, 13:58 | |
|
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
||||||
| 14.05.2021, 14:27 | ||||||
|
Добавлено через 4 минуты И еще одно. Если учителя и группу Вы выбираете из списков (ComboBox), то не надо никакой новой модели, просто добавьте в комбобоксы кроме отображаемых строк еще и Value, куда и заносите айдишники. Их-то и извлекайте для подстановки в запрос на выборку для проверки. Добавлено через 34 секунды ![]() Добавлено через 5 минут danhiroman, Перечитал внимательно еще раз [32]. Возникли некоторые мысли:
0
|
||||||
|
2 / 2 / 0
Регистрация: 26.05.2020
Сообщений: 331
|
||
| 14.05.2021, 14:40 [ТС] | ||
|
0
|
||
|
|
||
| 14.05.2021, 14:44 | ||
![]() Ну и конечно под это представление сделать модель в клиенте. А так проверки можно делать по разному, один из вариантов с MERGE и временной таблицей. Передаем новые данные во времянку, с помощью MERGE проводим все проверки и выполняем что надо из условия, либо отклоняем добавление, либо переписываем, либо удаляем Ну и в клиенте ловим эксепшены, которые генерируем в хранимке с MERGE.
0
|
||
|
2 / 2 / 0
Регистрация: 26.05.2020
Сообщений: 331
|
|
| 14.05.2021, 17:47 [ТС] | |
|
MsGuns, Спасибо за помощь и потраченное время. Вроде бы получилось сделать проверку.
0
|
|
|
14330 / 9423 / 1356
Регистрация: 21.01.2016
Сообщений: 35,517
|
|||
| 18.05.2021, 09:10 | |||
|
0
|
|||
|
112 / 110 / 30
Регистрация: 08.05.2021
Сообщений: 485
|
||||
| 18.05.2021, 09:59 | ||||
|
Кстати, выше он привёл код, в котором ошибся именно так, как я и сказал. Смотри sql в базу от этого кода, если интересно. Не поймёшь - пасти полную транзакцию сюда, попробую объяснить.
0
|
||||
| 18.05.2021, 13:47 | |
|
0
|
|
| 18.05.2021, 13:47 | |
|
Помогаю со студенческими работами здесь
40
Подскажите как сделать форму добавление записи в DBGrid Как сделать добавление/редактирование/удаление записи в dbgrid? Как сделать добавление записи через запрос в Access Как сделать проверку на пустую строку и проверку что в слове нет повторяющихся букв Как добавлять записи в файл, делая проверку на пустые записи Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта
Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
|
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром.
возможно получится прикрутить интерпретатор питон для кастомизации игровой логики.
что есть на текущий момент:. . .
|
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2.
Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
|
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
|
|
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2.
Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
|
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2.
Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом.
В. . .
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|