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

Как сделать простейший триггер сравнивающий 2 даты?

29.08.2019, 14:14. Показов 1963. Ответов 2

Студворк — интернет-сервис помощи студентам
Подскажите мне - я тупой? В чем проблема то а? Как сделать простейший триггер сравнивающий 2 даты чтобы одна не была бльш другой.
SQL
1
2
3
4
5
6
7
8
9
10
11
USE BuildMat
GO
CREATE TRIGGER trg
ON Товар
AFTER INSERT 
AS (SELECT * FROM Товар p 
            JOIN inserted AS i
            ON p.ID_Товара=i.ID_Товара)
IF p.Годен_c>p.До 
BEGIN PRINT 'Укажите правильную дату' 
END;
Проблема такая :"Не удалось выполнить привязку составного идентификтора" в предпоследней строчке.
И еще - как сделать скалярную функцию сравнивающую числа из столбцов РАЗНЫХ таблиц
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.08.2019, 14:14
Ответы с готовыми решениями:

Как сделать так, чтобы даты формата 12/2/1232 не воспринимались как даты а оставались как текст?
Доброго всем времени суток, подскажите, как сделать так что-бы даты формата 12/2/1232 не воспринимались как даты а оставались как текст?...

Как сделать выборку периода даты в запросе с вычислением от запрошенной даты
Доброго времени суток! Есть форма, есть подчинённая форма, при запуске формы запрашивается "Дата", как сделать чтобы в...

Как сделать запрос с выводом клиентов от даты взятия кредита до даты последней сплаты
Задание "вывод людей которые имели кредит в прошлом". Я так понял нужно создать запрос (не знаю какой, скорей всего "записи без...

2
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
29.08.2019, 14:27
Лучший ответ Сообщение было отмечено Dangalah_1nah как решение

Решение

Вижу в триггере какой-то SELECT "в никуда" и какой-то IF "сам по себе".
Откуда может этот IF знать, что такое p???
T-SQL
1
2
3
4
5
6
7
8
IF EXISTS
(
 SELECT *
 FROM Товар p 
 JOIN inserted i ON p.ID_Товара=i.ID_Товара
 WHERE i.Годен_c>i.До
)
RAISERROR(16,0,0,'Укажите правильную дату') WITH NOWAIT;
Я тут исправил проверку всех записей таблицы на проверку только "новых" записей...
Может, это неправильно. Тогда извиняйте.

Про RAISERROR: https://docs.microsoft.com/ru-... erver-2017

Кстати,уровень ошибки, может, должен быть посерьёзнее, чтобы прервать триггер (и транзакцию откатить)
1
0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 6
29.08.2019, 19:15  [ТС]
Вроде работает, но выдает ошибку при дате меньше начальной, правда текст ошибки далеко не такой как указан.

Добавлено через 38 минут
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
USE [BuildMat]
GO
ALTER TRIGGER [dbo].[trg]
ON [dbo].[Товар]
AFTER  INSERT AS
IF EXISTS
(
 SELECT *
 FROM Товар p 
 JOIN inserted i ON p.ID_Товара=i.ID_Товара
 WHERE i.[Годен_с:]>i.До
)
RAISERROR(24,-1,-1,'Укажите правильную дату') ;
Вот что получилось - жалко что с UPDATE вообще ничего не происходит, только при вставке выходит ошибка с кучей текста
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.08.2019, 19:15
Помогаю со студенческими работами здесь

Как сделать простейший фильтр по производителю?
Надо, что при отключении checkbox соответствующий li исчезал. <div class="row" style="padding: 0"> <div...

Как сделать простейший датчик положения
Существует задача - включать/выключать диодную подсветку (для определенности небольшой rgb светодиод). Состояние диода горит/не горит...

Как сделать на Delphi простейший платформер
Доброго времени суток! Давно программирую на Delphi, однако ни разу не писал игры. Хочу попробовать сделать простенький платформер, однако...

как сделать простейший поиск элементов списке
• При взятии каждой книги вводится номер УДК и программа уменьшает количество книг на 1 или выдает сообщение об отсутствии книги или о том,...

Как в базе данных, в запросе сделать так, чтобы пользователь вводил даты, и если такой даты нету, то выводило окно "тако
Как в базе данных, в запросе сделать так, чтобы пользователь вводил даты, и если такой даты нету, то выводило окно "такой даты нет,...


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

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

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: показать затраченные материалы за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В качестве. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru