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

Триггер на изменение INSERT

19.12.2015, 03:44. Показов 1785. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!

Есть таблица shop:
SQL
1
2
3
4
5
6
7
8
9
CREATE TABLE shop
(
shop_id INT IDENTITY(1,1) NOT NULL PRIMARY KEY,
nubmer INT,
title VARCHAR(20),
region_rozm VARCHAR (20),
profil VARCHAR(20),
capital INT
)
Нужно сделать триггер, который при вставке значений в эту таблицу ставил бы поле capital равное трем в любом случае, чтобы в этот capital не вводили.

Пытался разными способами, работает при AFTER INSERT, но мне нужно именно при INSERT. Но ничего не получается

SQL
1
2
3
4
5
6
7
8
9
CREATE TRIGGER UpdCascadeTrig4
  ON shop
  FOR INSERT
  AS
  IF @@ROWCOUNT = 23 AND @@ROWCOUNT = 40
  BEGIN
  UPDATE shop SET shop.capital = 3
  SELECT * FROM inserted
END
Добавлено через 13 минут
А может, если нельзя просто вставить, то создать отдельную таблицу, в которой будет только поле со значением "3" и это поле каждый раз присваивать полю capital таблицы shop?

Добавлено через 22 минуты
Сделал вот такой рабочий триггер, но теперь мне нужно еще выполнить условие, чтобы обрабатывались только строки от четвертой до десятой. Как правильно здесь задать условие @@ROWCOUNT?

SQL
1
2
3
4
5
6
7
8
9
CREATE TRIGGER UpdCascadeTrig43
  ON shop
  FOR INSERT
  AS
  UPDATE shop
  SET capital = 3
  FROM shop AS F
  JOIN Inserted AS I
  ON F.shop_id = I.shop_id
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.12.2015, 03:44
Ответы с готовыми решениями:

Триггер AFTER INSERT
Здравствуйте, ребята! Существует таблица, на ней триггер AFTER INSERT. Тело триггера примерно такое create trigger after_insert on...

Триггер на Insert в БД
Данные упрощаю, но суть от этого не меняется Есть табличка Table id_table Name Number Info

Триггер INSERT
Помогите написать триггер. Есть 2 таблицы: Улица и Сотрудник. Улица: Наименование; Сотрудник: Табельный_номер Фамилия .... ...

5
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
19.12.2015, 11:46
Сделайте вычисляемое поле. Зачем триггер?
0
0 / 0 / 0
Регистрация: 24.12.2012
Сообщений: 15
19.12.2015, 13:29  [ТС]
Да сделал бы, но задали именно триггер, что поделать. Мне осталось только задать условия с какой по какую строку работать и все. Может есть идеи?

Добавлено через 1 час 11 минут
Все, разобрался сам, оказалось довольно просто и без заморочек. Вот код триггера для потомков

SQL
1
2
3
4
5
6
7
8
9
10
11
12
CREATE TRIGGER UpdCascadeTrig43
  ON shop
  FOR INSERT
  AS 
 BEGIN
  UPDATE shop
  SET capital = 3
  FROM shop AS F
  JOIN Inserted AS I
  ON F.shop_id = I.shop_id
  WHERE (I.shop_id BETWEEN 4 AND 10)
  END
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
19.12.2015, 17:36
Цитата Сообщение от Мелифаро Посмотреть сообщение
Да сделал бы, но задали именно триггер, что поделать. Мне осталось только задать условия с какой по какую строку работать и все. Может есть идеи?

Добавлено через 1 час 11 минут
Все, разобрался сам, оказалось довольно просто и без заморочек. Вот код триггера для потомков

SQL
1
2
3
4
5
6
7
8
9
10
11
12
CREATE TRIGGER UpdCascadeTrig43
  ON shop
  FOR INSERT
  AS 
 BEGIN
  UPDATE shop
  SET capital = 3
  FROM shop AS F
  JOIN Inserted AS I
  ON F.shop_id = I.shop_id
  WHERE (I.shop_id BETWEEN 4 AND 10)
  END
Если буду вставлять запись с capital = 3, то триггер будет его всё равно менять на 3?
А зачем? Добавить в WHERE ещё одно условие - что может быть проще!
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
19.12.2015, 20:50
Цитата Сообщение от iap Посмотреть сообщение
WHERE (I.shop_id BETWEEN 4 AND 10)
это как?
сорри, не к iap, конечно вопрос
0
0 / 0 / 0
Регистрация: 24.12.2012
Сообщений: 15
23.12.2015, 21:22  [ТС]
В смысле как? По айдишнику выбираем записи от 4 до 10 и меняем только их
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.12.2015, 21:22
Помогаю со студенческими работами здесь

Триггер INSTEAD OF INSERT
Уважаемые программисты, помогите решить возникнувший вопрос по поводу триггера INSTEAD OF INSERT в T-sql. Есть такой код: CREATE...

Создать триггер Insert
Здравствуйте, имеется таблица Успеваемость с полями НомерЗачетнойКнижки(тип int), КодДисциплины(nvchar) и Оценка(int).Нужно создать...

Триггер insert delete
помогите допилить триггер, начал только изучать sql, как сделать что бы он сработал еще на удаление! при удалении срабатывает на первом...

Триггер Insert, Update
Помогите написать триггер на запрет добавления существующего клиента в таблицу. Таблица состоит из фамилии и номера телефона

Триггер при поочерёдном insert'e
Использую триггер after insert Он срабатывает после того, как вызовется оператор insert Проблема вот в чём: у меня идёт множественный...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
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 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru