Ошибка (2,7): PLS-00428: в этом операторе SELECT ожидается предложение INTO - PullRequest
1 голос
/ 17 января 2011

Я пытаюсь создать этот триггер и получаю следующие ошибки компилятора:

create or replace
TRIGGER RESTAR_PLAZAS
AFTER INSERT ON PLAN_VUELO
BEGIN
SELECT F.NRO_VUELO, M.CAPACIDAD, M.CAPACIDAD - COALESCE((
SELECT count(*) FROM PLAN_VUELO P
WHERE P.NRO_VUELO = F.NRO_VUELO
       ), 0) as PLAZAS_DISPONIBLES
FROM VUELO F
      INNER JOIN MODELO M ON M.ID = F.CODIGO_AVION; 
END RESTAR_PLAZAS;


Error(2,7): PL/SQL: SQL Statement ignored
Error(8,5): PL/SQL: ORA-00933: SQL command not properly ended
Error(8,27): PLS-00103: Encountered the symbol "end-of-file" when expecting one of the following:     begin case declare end exception exit for goto if loop mod    null pragma raise return select update while with    <an identifier> <a double-quoted delimited-identifier>    <a bind variable> << close current delete fetch lock insert    open rollback savepoint set sql execute commit forall merge    pipe 
Error(2,1): PLS-00428: an INTO clause is expected in this SELECT statement

Что не так с этим триггером?

Ответы [ 3 ]

2 голосов
/ 17 января 2011

Вам не разрешат

SELECT count (*) ОТ PLAN_VUELO

в триггере на PLAN_VUELO

Не использоватьтриггер.Используйте хранимую процедуру.

1 голос
/ 24 сентября 2012

Просто добавьте предложение into в соответствии с типом результата, например:

declare
  my_result VUELO%rowtype;
begin
  select v.* into my_result from VUELO v where id = '1';
end;
1 голос
/ 17 января 2011

Внутри блока PL / SQL вы должны SELECT ... INTO что-то. У меня был пример этого в ответе на один из ваших вопросов вчера. В этом случае вы можете выбрать локальную переменную и использовать результат для обновления другой таблицы.

Но похоже, что вы, вероятно, получите много результатов обратно, потому что вы не ограничены интересующей вас ценностью; предложения WHERE не фильтруют ни одно из значений :NEW вставленной строки. Это приведет к ORA-02112. Вы должны убедиться, что ваш выбор вернет ровно одну строку, или посмотрите на курсоры, если вы действительно хотите иметь несколько строк.

...