У меня есть эта таблица, которая представляет слабую сущность и является типичной таблицей для представления упорядоченных элементов: вставьте в значения ITEM_FORNECIMENTO (a_orderId, a_prodId, a_prodQtd, a_buyPrice);
Я хочу, чтобы мой триггер обновил последнююстолбец (общая цена продуктов без iva), чтобы сделать это: totalPrice = totalPrice * (1+ (iva / 100), каждый раз, когда я вставляю или обновляю запись в этой таблице.
, поэтому я подошелс этим, но я совершенно не прав, когда дело доходит до работы с новыми и старыми значениями.
create or replace
trigger t_replaceTotal
after insert or update of id_prod,qtd_if,prec_total_if on item_fornecimento
for each row
declare
iva produto.iva_prod%type;
idProd produto.id_prod%type;
r_old item_fornecimento.prec_total_if%type:=null;
r_new item_fornecimento.prec_total_if%type:=null;
begin
select iva_prod,id_prod into iva,idprod from produto p where p.id_prod = id_prod;
r_old:= :old.prec_total_if;
r_new:= :new.prec_total_if;
update item_fornecimento item set prec_total_if = r_old * (1+(iva/100)) where item.id_prod = idprod;
end;
Может кто-нибудь, пожалуйста, помогите переписать этот код? Я получаю ошибку: ORA-01422: точная выборкавозвращает больше запрошенного числа строк ORA-06512: в «FUSION.T_REPLACETOTAL», строка 8 ORA-04088: ошибка во время выполнения триггера «FUSION.T_REPLACETOTAL '