Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 6

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

29.08.2019, 14:14. Показов 1952. Ответов 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 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Данные берутся из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru