我的一位同事在从 Java 创建 Oracle 队列的(非持久)订阅者时遇到问题。
队列由一个模式拥有(比如 OWNER);他正试图以另一个用户(比如订阅者)的身份连接。SUBSCRIBER 已被 OWNER 授予 DEQUEUE 特权(以及 ENQUEUE,就其价值而言)。
当他创建队列并将“multiple_consumers”选项设置为 FALSE 时,一切正常。当“multiple_consumers”设置为 TRUE(我们需要的设置)时,它会失败并显示以下内容:
oracle.jms.AQjmsException: ORA-01031: insufficient privileges
ORA-06512: at "SYS.DBMS_AQADM_SYS", line 5757
ORA-06512: at line 1
ORA-06512: at "SYS.DBMS_AQJMS", line 129
ORA-06512: at line 1
at oracle.jms.AQjmsSession.addDurableSubscriber(AQjmsSession.java:3708)
at oracle.jms.AQjmsSession.createSubInOldMode(AQjmsSession.java:2742)
at oracle.jms.AQjmsSession.createDurableSubscriber(AQjmsSession.java:2400)
at oracle.jms.AQjmsSession.forceCreateOldSubscriber(AQjmsSession.java:2884)
at oracle.jms.AQjmsSession.createConsumer(AQjmsSession.java:6820)
如果他以 OWNER 身份连接,则成功。
如何确定需要授予 SUBSCRIBER 哪些权限?