Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
8 / 8 / 3
Регистрация: 22.09.2012
Сообщений: 179

Тригер на изменение таблицы

07.03.2016, 17:12. Показов 500. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
USE [test]
GO
/****** Object:  Trigger [dbo].[nameTriger]    Script Date: 07.03.2016 21:09:34 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER TRIGGER [dbo].[nameTriger] ON [test].[dbo].[name]
INSTEAD OF UPDATE
AS
BEGIN
DECLARE @OldName nvarchar(10)
DECLARE @oldID INT 
SET @OldName = (SELECT [name]
FROM [test].[dbo].[name] WHERE id = @@IDENTITY);
SET @oldID = (SELECT  [id]
FROM [test].[dbo].[name] WHERE id = @@IDENTITY );
 
BEGIN
    INSERT INTO [test].[dbo].[nameHistory] (id, name)
    VALUES (@oldID, @OldName)
      END
END
Он хорошо отрабатывает, если одна строка обновляется, если несколько, то в таблицу аудита пишет только одну строку.

Подскажите пожалуйста, что не так? Или нельзя уловить обновление больше одной строки за одну команду update?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.03.2016, 17:12
Ответы с готовыми решениями:

Тригер на изменение таблицы
Товарищи, такая ситуация есть таблица t1 с столбцами p1 и p2. Столбец p1 сразу заполняется, а p2 позже. Помогите пожалуйста написать...

Тригер записи или обновления таблицы
Есть запись из двух в одну таблицу. --Вставка в общую БД insert into Piramida2000.dbo.data (PARNUMBER, OBJECT, ITEM, VALUE0, VALUE1,...

Тригер на Update всей таблицы и запись стараых данных в таблицу History
Тело тригера: CREATE TRIGGER ON .. FOR update AS BEGIN DECLARE @id int; DECLARE @new_str nvarchar(32); SET @id = (select...

1
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
07.03.2016, 19:14
Чему же, по-вашему, равно @@IDENTITY в этом триггере?
Надо пользоваться псевдотаблицами inserted и deleted,
в которых лежат записи до и после обновления.
Однако, у вас триггер INSTEAD OF UPDATE. Где же в нём написан UPDATE?
Впрочем, может, он такой хитрый, что вместо UPDATE делает INSERT в другую таблицу - NameHistory...

Цитата Сообщение от Evgeniy_Fox Посмотреть сообщение
Он хорошо отрабатывает
Бла-бла-бла
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.03.2016, 19:14
Помогаю со студенческими работами здесь

Стиль в коде. Тригер, как сделать так, чтобы тригер менял кисть на ту, которая в свойстве контрола
Есть код, работает, но мне нужно, чтобыменялся цвет не на жёстко прописанный Red, а на RectBorderBrush. Как? using System.Windows; ...

Тригер для редактирования таблицы
Добрый день. Проблема достаточно простая на первый взгляд, но курение мануалов мне не помогло. задача следующая: при удалении...

Изменение поля таблицы на поле из другой таблицы
Есть 2 таблицы: product и prod_type В первой хранятся продукты, во второй типы продуктов В первой таблице есть поля p_price, p_type и...

Тригер
БД «Мировые рыбные ресурсы» Тригер: розробити тригер на додання/зміну записів у таблиці «Рыбы», такий, щоб забороняти додавання запису,...

Тригер
Можно ли в тригере зделать update? если да то как?


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru