PDA

Показать полную графическую версию : Проблемы с созданием и вызовом PL/SQL процедур в oracle XE


ElVоvan
11-05-2008, 21:14
Для обучения 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
http://download.oracle.com/docs/cd/B19306_01/appdev.102/b14261/toc.htm
Очень рекомендую читать официальную документацию.

ElVоvan
18-05-2008, 14:23
Что-то не сильно помагает, у меня и так книга от авторов, работающих в оракл.

Взял один из примеров, приведённых по ссылке:
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
Странные какие-то глюки были, всё заработало, проблема была в неправильном символе перехода на новую строку (я текст в gedit'е набирал), если набирать непосредственно в окошке веб-интерфейса или в каком-нибудь другом редакторе, то всё работает нормально...

merrat
13-06-2008, 14:44
ADD_JOB(id JOBS.JOB_ID%type,title JOBS.JOB_TITLE%type) as »

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

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 выполняющейся по расписанию




© OSzone.net 2001-2012