После некоторой борьбы с Oracle Advanced Queuing и пакетом dbms_aq я столкнулся с другая проблема. Я скопировал код из руководств Oracle, но когда я компилирую этот код:
create or replace
procedure jms_test(msg varchar2)
is
id pls_integer;
message sys.aq$_jms_stream_message;
enqueue_options dbms_aq.enqueue_options_t;
message_properties dbms_aq.message_properties_t;
begin
message := sys.aq$_jms_stream_message.construct(0);
message.set_string_property('FROM', 'TEST');
id := message.clear_body(-1);
end;
он жалуется на:
Error(9,40): PLS-00302: component 'CONSTRUCT' must be declared
Error(10,10): PLS-00302: component 'SET_STRING_PROPERTY' must be declared
Error(11,16): PLS-00302: component 'CLEAR_BODY' must be declared
Я думаю, что этот код работает вне тела процедуры, потому что я успешно пробовал рецепты из Что находится в моей очереди JMS?
Моя версия Oracle: Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production
Есть идеи, что может быть не так?