如何从 PL/SQL 将消息发布到 Oracle AQ 消息队列上的主题

问题描述 投票:0回答:2

我知道我可以使用 JMS TopicPublisher 将消息从 java 代码发布到 Oracle AQ 队列(有大量文档和示例),但我确实还需要从 PL/SQL 代码将消息发布到给定主题到 Qracle AQ 队列。 我找不到有关如何执行此操作的文档或示例。是否可以?有人能给我指出正确的文档或示例位置吗???

任何帮助表示赞赏,

扬·范德克洛克

oracle plsql publish advanced-queuing
2个回答
2
投票

您可以在Streams 高级队列用户指南

中找到所有带有示例的信息

下面的示例是从文档中提取的,并进行了细微的更改

    CREATE TYPE message_typ AS object(
       sender_id              NUMBER,
       subject                VARCHAR2(30),
       text                   VARCHAR2(1000));
    /


    BEGIN
       DBMS_AQADM.CREATE_QUEUE_TABLE(
          queue_table            => 'obj_qtab',
          queue_payload_type     => 'message_typ',
          multiple_consumers     => true
          );
    END;
    /

    BEGIN
       DBMS_AQADM.CREATE_QUEUE(
          queue_name         =>  'obj_queue',
          queue_table        =>  'obj_qtab');
    END;
    /

    BEGIN
       DBMS_AQADM.START_QUEUE (
          queue_name         => 'obj_queue');
    END;
    /

DECLARE
   subscriber         sys.aq$_agent;
BEGIN
   subscriber     :=  sys.aq$_agent('RED', NULL, NULL);
   DBMS_AQADM.ADD_SUBSCRIBER(
      queue_name  =>  'obj_queue',
      subscriber  =>  subscriber);

   subscriber     :=  sys.aq$_agent('GREEN', NULL, NULL);
   DBMS_AQADM.ADD_SUBSCRIBER(
      queue_name  =>  'obj_queue',
      subscriber  =>  subscriber); 

         subscriber     :=  sys.aq$_agent('YELLOW', NULL, NULL);
   DBMS_AQADM.ADD_SUBSCRIBER(
      queue_name  =>  'obj_queue',
      subscriber  =>  subscriber);

END;
/

脚本执行以下操作:创建对象、创建队列表、创建队列、启动队列并注册 3 个订阅者。

DECLARE
   enqueue_options     DBMS_AQ.enqueue_options_t;
   message_properties  DBMS_AQ.message_properties_t;
   recipients          DBMS_AQ.aq$_recipient_list_t;
   message_handle      RAW(16);
   message             message_typ;

    recipients2          DBMS_AQ.aq$_recipient_list_t;
BEGIN
   message := message_typ(001, 'MESSAGE 1','For queue subscribers');
   DBMS_AQ.ENQUEUE(
      queue_name          => 'obj_queue',
      enqueue_options     => enqueue_options,
      message_properties  => message_properties,
      payload             => message,
      msgid               => message_handle);
-- Message for all subscriber

   message := message_typ(001, 'MESSAGE 2', 'For two recipients');
   recipients(1) := sys.aq$_agent('RED', NULL, NULL);
   recipients(2) := sys.aq$_agent('BLUE', NULL, NULL);
   message_properties.recipient_list := recipients;
   DBMS_AQ.ENQUEUE(
      queue_name          => 'obj_queue',
      enqueue_options     => enqueue_options,
      message_properties  => message_properties,
      payload             => message,
      msgid               => message_handle);
-- Message for RED,BLUE  subscriber   


   recipients2(1)   := sys.aq$_agent('RED', NULL, NULL);   
   message := message_typ(001, 'MESSAGE 3', 'For RED Subscriber');      
   message_properties.recipient_list := recipients2;
   DBMS_AQ.ENQUEUE(
      queue_name          => 'obj_queue',
      enqueue_options     => enqueue_options,
      message_properties  => message_properties,
      payload             => message,
      msgid               => message_handle);
-- Message for RED  subscriber   
   COMMIT;
END;
/

要检查结果,您必须查询队列表视图(

AQ$queue_table_name
)。
在这种情况下确实如此。

select o.user_data,CONSUMER_NAME  from AQ$obj_qtab o order by MSG_ID;

0
投票
If your message type in Queue table is SYS.AQ$_JMS_TEXT_MESSAGE.
DECLARE
   enqueue_options     DBMS_AQ.enqueue_options_t;
   message_properties  DBMS_AQ.message_properties_t;   
   message_handle      RAW(16);
   message             SYS.AQ$_JMS_TEXT_MESSAGE;
   timeStamp           VARCHAR2(85);
BEGIN
   message := SYS.AQ$_JMS_TEXT_MESSAGE.CONSTRUCT();
   timeStamp := to_char(systimestamp, 'YYYY-MM-DD"T"HH24:mm:ss.FF9"Z"');
   message.SET_TEXT('{"filedName1":"field_value","timeStamp_field":"'||timeStamp||'"}');
   DBMS_AQ.ENQUEUE(
      queue_name          => 'DB_Name.QueueName',
      enqueue_options     => enqueue_options,
      message_properties  => message_properties,
      payload             => message,
      msgid               => message_handle);
COMMIT;
END;
© www.soinside.com 2019 - 2024. All rights reserved.