Вход на хостинг
IT-новости
20.04.2016 iPhone 2017 года поместят в водонепроницаемый корпус из стекла
Линейка iPhone в новом году серьезно поменяется. В этом уверен аналитический исследователь Мин Чи Ку......
30.07.2015 Ищем уникальный контент для сайта
Ищем уникальный контент для сайта Без уникального контента Ваш сайт обречен на то, что его страницы......
execute procedure orders_after_insert();
Точно так же поступим с триггером для контроля обязательных остатков (здесь все заметно проще):
Create or replace function warehouse_after_update()
returns trigger as
'BEGIN
if NEW.count < (select rest from goods
where goods_id = NEW.goods_id) then
insert into goods_warnings(goods_id, message, date)
values(NEW.goods_id,
'Остаток меньше обязательного',
now());
end if;
return NEW;
END;'
language 'plpgsql';
Create trigger rest_control after update on warehouse
execute procedure warehouse_after_update();
На что здесь можно обратить внимание, так это на непосредственное использование результата выборки в качестве переменной (см. конструкцию «select» в скобках). Естественно, выборка должна возвращать одно значение требуемого типа. Ну и поскольку благодаря этому в функции удалось обойтись без переменных, секцию DECLARE за ненадобностью можно опустить.
И теперь приступаем к проверке работоспособности. Сначала оформим «штатный» заказ:
insert into orders(customer, goods_id, count, price, date)
values('Иванов Иван Иванович', 3, 1, 7302.00, '2004-07-15');
Убеждаемся, что на складе количество мониторов уменьшилось, записи в таблицах заказов и резерва появились, предупреждений нет. Теперь закажем сразу 4 монитора:
insert into orders(customer, goods_id, count, price, date)
values('Горэлектросети', 3, 4, 7302.00, '2004-07-16');
Чтобы проверить правильность отмены просроченных заказов, даты выше были указаны прошедшие. Если сейчас заказать 10 мониторов, то заказ будет помечен как «not reserved», и соответствующая запись появится в таблице предупреждений. Поскольку даже с учетом просроченных заказов 10 мониторов никак не набирается, то и аннулироваться ничего не будет. А вот если заказать 3 монитора, то с учетом высвобождения просроченного резерва (5 штук) нужное количество набирается и даже 2 монитора будут возвращены на склад. В таблице предупреждений появится 4 записи – две об аннулировании просроченных заказов, одна о том, что имела место нехватка товара на складе, и одна о том, что остаток мониторов (4 шт.) меньше обязательного минимума (5 шт.).