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

Тригер на обновление статуса заказа

16.12.2021, 19:14. Показов 842. Ответов 1

Author24 — интернет-сервис помощи студентам
Есть код, но работает он не так как должен

По сути работать он должен так: в перменную @kodzakaza мы выводим Код Заказа только что изменненого Статуса вещи.
В @status_vrab мы выводим количество вещей с айди = @kodzakaza у которых статус заказа = "В работе".
В @status_gotovo мы выводим количество вещей с айди = @kodzakaza у которых статус заказа = "Готово".
Далее проводится проверка если @status_vrab=@status_gotovo то мы обновляем в таблице Заказы статус на "Готов".
Иначе(или же в случае изменения статуса вещи) мы обновляем статус заказа в таблице Заказы на "В работе".

Что происходит по факту, при смене статуса вещи(вне зависимости от количества строк с одним айди Закза) на "Готов" ничего не происходит, а при изменении статуса этой же вещи на "В работе", статус Заказа(измененный в ручную на "Готово" изменяется на "В работе".

SQL Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
ALTER TRIGGER [dbo].[update_status]
ON [dbo].[UslugiVCheke]
AFTER UPDATE
AS
BEGIN
DECLARE @kodzakaza INT
SELECT @kodzakaza = kodZakaza FROM inserted
 
DECLARE @status_vrab INT
SELECT @status_vrab = COUNT(*) FROM inserted
WHERE inserted.kodZakaza=@kodzakaza AND StatusVeshi=N'В работе'
 
DECLARE @status_gotovo INT;
SELECT @status_gotovo = COUNT(*) FROM inserted
WHERE inserted.kodZakaza=@kodzakaza AND StatusVeshi=N'Готово'
 
IF @status_vrab=@status_gotovo
UPDATE Zakaz SET StatusZakaza='Готово' WHERE KodZakaza=@kodzakaza
 
ELSE
UPDATE Zakaz SET StatusZakaza='В работе' WHERE KodZakaza=@kodzakaza
END
Тригер на обновление статуса заказа
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.12.2021, 19:14
Ответы с готовыми решениями:

Ведение статуса заказа
Как реализовать ведение статуса заказа? К примеру покупатель приобретает товар с доставкой и в статусе появляется "Активно"

Отслеживание статуса заказа
Вобщем суть вопроса такова: хочу создать небольшой закрытый сайт для оптовых покупателей, и надо сделать такой пункт меню, как...

форма на сайт статуса заказа
Привет! Помогите, плизз, создать скрипт. Нужна форма ввода заказа или логина, которая будет сверяться с файлом, и если там есть этот...

1
0 / 0 / 0
Регистрация: 16.05.2021
Сообщений: 35
16.12.2021, 19:27  [ТС]
Изменив код у меня получилось придти к тому что при изменении статуса одного из вещей, статус заказа так же меняется, однако если вещей несколько то статус заказа присвает себе статус последнего измененного элемента, не смотря на то что у другой вещи статус стоит совершенно противоположный, а такого быть не должно.
SQL Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
ALTER TRIGGER [dbo].[update_status]
ON [dbo].[UslugiVCheke]
AFTER UPDATE
AS
BEGIN
DECLARE @kodzakaza INT
SELECT @kodzakaza = kodZakaza FROM inserted
 
/*declare @status_vrab int
select @status_vrab = count(*) from inserted
where inserted.kodZakaza=@kodzakaza and StatusVeshi=N'В работе'*/
 
DECLARE @status_gotovo INT;
SELECT @status_gotovo = COUNT(*) FROM inserted
WHERE inserted.kodZakaza=@kodzakaza AND StatusVeshi=N'Готово'
 
IF COUNT(@kodzakaza)=@status_gotovo
UPDATE Zakaz SET StatusZakaza='Готово' WHERE KodZakaza=@kodzakaza
 
ELSE
UPDATE Zakaz SET StatusZakaza='В работе' WHERE KodZakaza=@kodzakaza
END
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.12.2021, 19:27
Помогаю со студенческими работами здесь

УТ 11.2. Изменение статуса заказа клиента.
Добрый день! Помогите пожалуйста разобраться! В УТ 11.2 есть документ заказ клиента. На общей форме документа есть реквизиты ...

В таблице order не изменяется поле статуса заказа
Здравствуйте! При использую php в связке с MySql у меня почему то не изменяется статус заказа с '0' на '1'. Поле заказа имеет тип...

Обновление статуса
Необходимо в Stringgrid добавить статус рейса (отправлен/ожидается), желательно чтобы он обновлялся в реальном времени, как например в...

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

Компонент оформления заказа sale.order.ajax. Обработать новую ошибку в оформлении заказа
Добрый день, последняя надежда на данный форум. Мне нужно получать "хороший" адрес доставки, для этого использую АПИ Яндекс карт. А...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Работа с объемным DOM в javascript
Htext 04.04.2025
Сегодня прочитал статью тут о расходах памяти в JS, ее утечках и т. п. И вот что вспомнил из своей недавней практики. Может, кому пригодится. Хотя, в той статье об этом тоже есть. Дело в том, что я. . .
Оптимизация производительности Node.js с помощью кластеризации
run.dev 04.04.2025
Масштабирование приложений для обработки тысяч и миллионов запросов — обыденная задача для многих команд. Node. js, благодаря своей асинхронной событийно-ориентированной архитектуре, стал популярной. . .
Управление зависимостями в Python с Poetry
py-thonny 04.04.2025
Стандартный инструмент для установки пакетов в Python - pip - прекрасно справляется с базовыми сценариями: установил пакет командой pip install и используешь его. Но что произойдёт, когда разные. . .
Мониторинг с Prometheus в PHP
Jason-Webb 04.04.2025
Prometheus выделяется среди других систем мониторинга своим подходом к сбору и хранению метрик. В отличие от New Relic, который использует агентный подход и отправляет данные во внешнее хранилище,. . .
Пакет Context в Golang: Управление потоками и ресурсами
golander 04.04.2025
Работа с горутинами в Go часто напоминает управление непослушными детьми - они разбегаются кто куда, делают что хотят и не всегда завершаются вовремя. К счастью, в Go 1. 7 появился пакет context,. . .
Контейнеризация React приложений с Docker
Reangularity 03.04.2025
Контейнеризация позволяет упаковать приложение со всеми его зависимостями в автономный контейнер, который можно запустить на любой платформе с установленным Docker. Это существенно упрощает процессы. . .
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
std::mutex в C++: Советы и примеры использования
bytestream 03.04.2025
std::mutex - это механизм взаимного исключения, который гарантирует, что критический участок кода выполняется только одним потоком в каждый момент времени. Это простое, но могущественное средство. . .
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер