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

Триггер между двумя таблицами

04.05.2019, 15:24. Показов 2356. Ответов 3

Студворк — интернет-сервис помощи студентам
Пишу Базу данных для склада (для курсовой). Есть две таблицы: Products и Operations. В первой информация о продукте (ID, Title, Category, Count), во второй информация о списании и поступлении продуктов (ID, WorkerID, ProductID, Count, Act (типа BIT, 1 - это поступление, 0 - списание)). Нужно написать триггер, который при поступлении товара будет прибавлять Operations.Count к Products.Count и вычитать при списании. Есть что-то вот такое (пока только для поступления):
T-SQL
1
2
3
4
5
6
7
8
9
10
11
USE StorageDataBase;
 
GO
 
CREATE TRIGGER Operations_INSERT_UPDATE
ON Operations
AFTER INSERT, UPDATE
AS IF (SELECT TOP 1 Operations.Act FROM Operations ORDER BY OpeationID DESC) = 1
        (SELECT Products.Count FROM Products WHERE 
            ((SELECT TOP 1 Operations.ProductID FROM Operations ORDER BY OpeationID DESC) = Products.ProductID))
            += SELECT TOP 1 Operations.Count FROM Operations ORDER BY OpeationID DESC
, но в последней строке жалуется на "+=" (если в t-sql вообще можно использовать такое, да и на просто "=" он жалуется на неверный синтаксис). Написано наверное костыльно, но исходя из того, что знаю, а может это вообще не то, что нужно. Буду рад почитать ваши варианты решения задачи или исправления моего.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.05.2019, 15:24
Ответы с готовыми решениями:

Разность между двумя таблицами
Существует 2 таблицы с такими данными: Как мне вывести данные первой таблицы при этом и первой таблицы "count" вычислить...

Связь между двумя таблицами
По работе приходится изучать SQL сервер. С запросами SQL разобрался более или менее, сейчас изучаю проектирование базы. Такой вопрос, есть...

Интеллектуальный перенос данных между двумя таблицами (Merge)
В таблице А содержатся данные по адресным объектам. В контексте вопроса важно сказать, что в этой таблице есть улицы и дома. у каждого...

3
46 / 33 / 14
Регистрация: 12.09.2013
Сообщений: 167
04.05.2019, 16:36
Лучший ответ Сообщение было отмечено Ronin00 как решение

Решение

Кликните здесь для просмотра всего текста
Ronin00, Нет нет нет, это никуда не годится. Вы пытаетесь реализовывать логику на языке запросов к базе данных и удивленны, почему обычные "программистские" штучки здесь не прокатывают?)


Перефразируем задачу на понятный нам язык. Если мы говорим про то, что каждая операция поступления - это новая строка в таблице Operations, то необходимо создать триггер, который бы при добавлении новой строки в таблицу Operations, проверял значение поля ACT. Единица в данном поле означает увеличение количества товара на складе, 0 уменьшение.

В соответствии с этим задача становится очень простой - при попадании в триггер проверяем поле ACT, если в нём 1 - добавляем, иначе - уменьшаем.

SQL
1
UPDATE products SET COUNT = COUNT + NEW.count WHERE productID = NEW.ProductID
Кликните здесь для просмотра всего текста

Честно признаться, спроектированная Вам структура базы данных никуда не годиться. Она плохо маштабируется, не соответствует требованиям бизнес процессов и вообще очень кривая.
1
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
04.05.2019, 19:41
Цитата Сообщение от naHuka Посмотреть сообщение
UPDATE products SET COUNT = COUNT + NEW.count WHERE productID = NEW.ProductID
Это что за фигня? Для какого сервера?
0
25 / 24 / 7
Регистрация: 22.08.2017
Сообщений: 130
11.05.2019, 10:16
Судя по синтаксису типа NEW.FieldName - на FireBird похоже
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.05.2019, 10:16
Помогаю со студенческими работами здесь

Задача с двумя таблицами
Подскажите, как можно реализовать? Даны две таблицы. первая - продукты. Там есть три поля - id, наименование и цена. Вторая таблица...

Связать одну таблицу с двумя другими таблицами
:) Уважаемые господа!! Помогите мне с одним моментом!! Дело вот в чём!! У меня допустим 3 таблицы есть и у каждой свои столбцы и ключи...

Связи между таблицами
Подскажите плз как установить связь например между Родительской Регион / КодРегиона и дочерней Поставщик / КодРегиона, Жму на отношения,...

Связи между таблицами
Объясните пжл на каком-нибудь жизненном примере что означают связи: 1:1, 1:M, M:M Вроде что-то понятно, но общей картины так и не...

Связь между таблицами
Бизнес-сущности: Список состоит из задач, разбитых на категории. Задача: дата, текст, список подзадач, ссылку на категорию,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru