Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/21: Рейтинг темы: голосов - 21, средняя оценка - 4.62
138 / 5 / 1
Регистрация: 25.03.2013
Сообщений: 228

Update trigger срабатывает при insert

17.11.2014, 11:23. Показов 4297. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть триггер, который должен срабатывать при изменение данных в таблице. Но он срабатывает не только при апдейте, но и при вставке данных. В чем проблема?
T-SQL
1
2
3
4
5
6
7
8
CREATE TRIGGER [dbo].[tr_imp_date] ON  [dbo].[applications] FOR UPDATE AS 
BEGIN
 SET NOCOUNT ON;
 UPDATE T
    SET T.implementation_date = getdate()
    FROM [dbo].[applications] T
    JOIN inserted i ON T.id = i.id
END
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.11.2014, 11:23
Ответы с готовыми решениями:

Trigger for insert
Приятного времени суток, уважаемые форумчане. Такой вопрос: Есть две связанные таблицы, при вставке записи в одну таблицу с...

After insert trigger
Помогите нужно применить его ,то есть показать как он работает желательно скрин или отчет Добавлено через 23 часа 30 минут кто...

Insert trigger
Добрый день. Помогите, пожалуйста, написать триггер на вставку записи с предварительной проверкой. Пусть имеем таблицу: Table1 (*ID,...

6
 Аватар для nixon93nixon
63 / 63 / 21
Регистрация: 08.02.2013
Сообщений: 262
17.11.2014, 11:46
сравнивай с данными таблицы deleted, например по id или другому уникальному полю.
Проще говоря, если существует запись с id, например, 123 и в таблице inserted и в таблице deleted то это определенно UPDATE и только после этой проверки выполняешь необходимые действия
1
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
17.11.2014, 11:48
Цитата Сообщение от o33ik Посмотреть сообщение
Но он срабатывает не только при апдейте, но и при вставке данных
Наверно, есть триггер на вставку, в котором происходит UPDATE.

Кстати, а как там у вас с настройками сервера по поводу вызова вложенных триггеров и рекурсии триггеров?
А то у Вас UPDATE внутри триггера на UPDATE.

Хорошо бы на входе проверять
T-SQL
1
IF EXISTS(SELECT * FROM inserted)
и апдейтить только действительно меняющиеся записи.
1
138 / 5 / 1
Регистрация: 25.03.2013
Сообщений: 228
17.11.2014, 11:59  [ТС]
iap, да, у меня есть триггер на вставку который делает update.
T-SQL
1
2
3
4
5
6
7
8
CREATE TRIGGER [dbo].[tr_date] ON  [dbo].[applications] FOR INSERT AS 
BEGIN
 SET NOCOUNT ON;
 UPDATE T
    SET T.creation_date = getdate()
    FROM [dbo].[applications] T
    JOIN inserted i ON T.id = i.id
END
всеравно, не понимаю что мне надо переделать?
0
 Аватар для nixon93nixon
63 / 63 / 21
Регистрация: 08.02.2013
Сообщений: 262
17.11.2014, 12:14
o33ik,
Цитата Сообщение от o33ik Посмотреть сообщение
iap, да, у меня есть триггер на вставку который делает update.
так вот когда вы вставляйте запись, срабатывает триггер на insert, который в свою очередь вызывает триггер на update
1
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
17.11.2014, 12:17
Цитата Сообщение от o33ik Посмотреть сообщение
iap, да, у меня есть триггер на вставку который делает update.
T-SQL
1
2
3
4
5
6
7
8
CREATE TRIGGER [dbo].[tr_date] ON  [dbo].[applications] FOR INSERT AS 
BEGIN
 SET NOCOUNT ON;
 UPDATE T
    SET T.creation_date = getdate()
    FROM [dbo].[applications] T
    JOIN inserted i ON T.id = i.id
END
всеравно, не понимаю что мне надо переделать?
А я не понимаю, как Вы не понимаете, что UPDATE в триггере на INSERT при вставке вызывает триггер на UPDATE
Вместо триггера на INSERT сделайте CONSTRAINT DEFAULT для поля creation_date.
Добавлено через 2 минуты
Цитата Сообщение от nixon93nixon Посмотреть сообщение
o33ik,
так вот когда вы вставляйте запись, срабатывает триггер на insert, который в свою очередь вызывает триггер на update
... который при определённых настройках на сервере вызывает тот же триггер на UPDATE,
в котором UPDATE снова вызывает триггер на UPDATE и так до 32-х раз!
На 33-й возвращается сообщение и всё откатывается.

Поэтому я про рекурсию триггеров и спрашивал.
1
138 / 5 / 1
Регистрация: 25.03.2013
Сообщений: 228
17.11.2014, 20:08  [ТС]
iap, а, про то что у меня вызывается тригер на апдейт понял.
Цитата Сообщение от iap Посмотреть сообщение
CONSTRAINT DEFAULT для поля creation_date
- это значение по умолчанию как я понял? При вставке записи, это поле будет автоматически заполнятся, тем чем я укажу, все верно?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.11.2014, 20:08
Помогаю со студенческими работами здесь

Теряются Юникодные символы при INSERT, UPDATE
Всем здрасте. Проблема такова: прямой вставкой copy/paste через Enterprise manager в ячейку можно воткнуть все что угодно (хоть...

create trigger instead of update
Всем привет! имеется следующее задание Разработайте INSTEAD OF-триггер(ы) для этого VIEW. При выполнении DML VIEW для триггер(ы) ...

Oracle trigger insert update
Уважаемые знатоки! имеется таблица create table UM_SESSION ( SESSION_ID NUMBER not null, START_DATE DATE, END_DATE ...

Insert trigger
дано задание: Данный триггер срабатывает на добавления цены в таблице «рыба-экземпляр», он срабатывает после добавления. Описание: в случае...

DOA + trigger *** instead of insert
Проблема : Связка Oracle+Delphi(DOA). Делаю вставку записи в вид. Вид на клиенте редактируется через OracleDataSet. Если на вид навешиваю ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru