Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Программирование и базы данных (http://forum.oszone.net/forumdisplay.php?f=21)
-   -   Проблемы с созданием и вызовом PL/SQL процедур в oracle XE (http://forum.oszone.net/showthread.php?t=106753)

ElVоvan 11-05-2008 21:14 799846

Проблемы с созданием и вызовом PL/SQL процедур в oracle XE
 
Для обучения PL/SQL использую Oracle XE, пользуюсь им через веб-интерфейс, я разблокировал демо-пользователя HR, который был в базе данных по-умолчанию, дал ему все полномочия, и использую заранее заготовленые демо-таблицы, но возникают некоторые проблемы. Например, мне нужно создать некоторую процедуру, я ввожу в поле для запросов следующий код
Код:

create or replace procedure
ADD_JOB(id JOBS.JOB_ID%type,title JOBS.JOB_TITLE%type) as
begin
        insert into JOBS (JOB_ID, JOB_TITLE)
        values (id,title);
end ADD_JOB;

мне в ответ выдаётся
Код:

Statement processed.
0,02 seconds

То есть, вроде бы всё нормально, процедура появляется в object browser'e. Теперь я пытаюсь вызвать процедуру из анонимного блока и добавить в таблицу пару строк:
Код:

declare
begin
        ADD_JOB('IT_DBA','Database Administrator');
        ADD_JOB('ST_MAN','Stock Manager');
end;

Вот тут мне выдаётся:
Код:

ORA-06550: line 3, column 2:
PLS-00905: object HR.ADD_JOB is invalid
ORA-06550: line 3, column 2:
PL/SQL: Statement ignored
ORA-06550: line 4, column 2:
PLS-00905: object HR.ADD_JOB is invalid
ORA-06550: line 4, column 2:
PL/SQL: Statement ignored
1. declare
2. begin
3.        ADD_JOB('IT_DBA','Database Administrator');
4.        ADD_JOB('ST_MAN','Stock Manager');
5. end;

У пользователя есть права на использование процедур, модификацю своих же таблиц, у него вообще все права есть, процедура и её вызов просто взяты из книжки и адаптированы под существующие таблицы.
Кто-нибудь может помочь всё же заставить процедуру запускаться?

whitedog 17-05-2008 23:07 805165

http://download.oracle.com/docs/cd/B...b14261/toc.htm
Очень рекомендую читать официальную документацию.

ElVоvan 18-05-2008 14:23 805476

Что-то не сильно помагает, у меня и так книга от авторов, работающих в оракл.

Взял один из примеров, приведённых по ссылке:
Код:

CREATE OR REPLACE PROCEDURE award_bonus (emp_id NUMBER, bonus NUMBER) AS
  commission        REAL;
  comm_missing EXCEPTION;
BEGIN  -- executable part starts here
  SELECT commission_pct / 100 INTO commission FROM employees
    WHERE employee_id = emp_id;
  IF commission IS NULL THEN
      RAISE comm_missing;
  ELSE
      UPDATE employees SET salary = salary + bonus*commission
      WHERE employee_id = emp_id;
  END IF;
EXCEPTION  -- exception-handling part starts here
  WHEN comm_missing THEN
      DBMS_OUTPUT.PUT_LINE('This employee does not receive a commission.');
      commission := 0;
  WHEN OTHERS THEN
      NULL; -- for other exceptions do nothing
END award_bonus;

Запускаю, в ответ пишет:
Код:

Procedure created
Потом запускаю свой пример, приведённый выше (я там переименовал только параметр id, тк id является ключевым словом, а в веб-интерфейсе подсветки нет), он выдаёт Statement proceeded, то есть выражение выполнено... Запускаю процедуру из примера - работает, запускаю свою - результат, что и в первом сообщении. Вроде прочёл про создание процедур и в книге и в документации по ссылке, делаю как и описано - CREATE OR REPLACE PROCEDURE <...> AS <...> BEGIN <...> END; но что-то толку от этого никакого, не могу сам разобраться, поэтому и прошу помощи....

ElVоvan 20-05-2008 20:50 807131

Странные какие-то глюки были, всё заработало, проблема была в неправильном символе перехода на новую строку (я текст в gedit'е набирал), если набирать непосредственно в окошке веб-интерфейса или в каком-нибудь другом редакторе, то всё работает нормально...

merrat 13-06-2008 14:44 825112

Цитата:

Цитата ElVоvan
ADD_JOB(id JOBS.JOB_ID%type,title JOBS.JOB_TITLE%type) as »

укажи типы явно.

Цитата:

Цитата ElVоvan
declare begin ADD_JOB('IT_DBA','Database Administrator'); ADD_JOB('ST_MAN','Stock Manager'); end; »


execute ADD_JOB('IT_DBA','Database Administrator');
execute ADD_JOB('ST_MAN','Stock Manager');

а вот так не пробЫвал?

PS: не называй идентификаторы типа job или jobs!
потомучто в оракле job - это специальный объект. т.е. блок pl/sql выполняющейся по расписанию


Время: 12:16.

Время: 12:16.
© OSzone.net 2001-