Adary,
 I am creating the procedure as system. I can select the table without no problem. 
I changed to all_users and worked fine, but the dbms_utility doesn't work.

Below is an example.

TIA

Ramon.

CREATE OR REPLACE PROCEDURE GENERAR_ESTADISTICAS AS
   CURSOR ESQUEMAS IS
       SELECT USERNAME ESQUEMA
          FROM ALL_USERS
       WHERE
          LENGTH(USERNAME <= 3 AND
          USERNAME         != 'SYS';
BEGIN
   FOR E IN ESQUEMAS
LOOP
   INSERT INTO EJECUCION_PROCEDIMIENTOS
      (PROCEDIMIENTO, FECHA_INICIO, FECHA_FIN, ESTATUS)
   VALUES  
      ('Generacion Estadisticas '||E.ESQUEMA, 
        TO_CHAR(SYSDATE, 'DD/MM/YYYY'),
        NULL,
       'Inicio');
--
   EXECUTE (DBMS_UTILITY.ANALYZE_SCHEMA(E.ESQUEMA, 'COMPUTE'));
--
   INSERT INTO EJECUCION_PROCEDIMIENTOS
      (PROCEDIMIENTO, FECHA_INICIO, FECHA_FIN, ESTATUS)
   VALUES  
      ('Generacion Estadisticas '||E.ESQUEMA, 
      NULL, 
      TO_CHAR(SYSDATE, 'DD/MM/YYYY'),
      'Finalizo');
END LOOP;
END;
/


SQL> EXECUTE GENERAR_ESTADISTICAS
BEGIN GENERAR_ESTADISTICAS; END;

*
ERROR at line 1:
ORA-20000: You have insufficient privileges for an object in this schema.
ORA-06512: at "SYS.DBMS_UTILITY", line 258
ORA-06512: at "SYSTEM.GENERAR_ESTADISTICAS", line 19
ORA-06512: at line 1


SQL> EXECUTE DBMS_UTILITY.ANALYZE_SCHEMA('SCOTT', 'COMPUTE');

PL/SQL procedure successfully completed.

SQL> sho user
USER is "SYSTEM"



-----Original Message-----
From:   "[EMAIL PROTECTED]" <[EMAIL PROTECTED]> on behalf of      "??? ?????" 
<[EMAIL PROTECTED]>
Sent:   Thursday, March 21, 2002 12:53 PM
To:     "Multiple recipients of list ORACLE-L" <[EMAIL PROTECTED]>
Subject:        RE: Error in procedure with dba_users

Tested it.
You do not have permission for dba_users.
You need to have role select_catalog_role.
On 8.1.6.3.4 on NT.


Yechiel Adar, Mehish Computer Services
[EMAIL PROTECTED]

> -----Original Message-----
> From: [EMAIL PROTECTED] [SMTP:[EMAIL PROTECTED]]
> Sent: Thu, March 21, 2002 5:33 PM
> To:   Multiple recipients of list ORACLE-L
> Subject:      Error in procedure with dba_users
> 
> Hi list,
> 
> I have this procedure under the system user, and when try to create it
> I get an error 
> 
> CREATE OR REPLACE PROCEDURE GENERAR_ESTADISTICAS AS
>    CURSOR ESQUEMAS IS
>        SELECT USERNAME ESQUEMA
>           FROM SYS.DBA_USERS
>        WHERE
>           USERNAME IN ('RAMON', 'SCOTT');
> BEGIN
>    FOR E IN ESQUEMAS
> LOOP
>    DBMS_UTILITY.ANALYZE_SCHEMA(E.ESQUEMA, 'COMPUTE');
> END LOOP;
> END;
> 
> 3/8      PL/SQL: SQL Statement ignored
> 4/16     PLS-00201: identifier 'SYS.DBA_USERS' must be declared
> 11/4     PL/SQL: Statement ignored
> 11/32    PLS-00364: loop index variable 'E' use is invalid
> SQL> 
> 
> Any help .
> 
> TIA 
> 
> Ramon E. Estevez
> -- 
> Please see the official ORACLE-L FAQ: http://www.orafaq.com
> -- 
> Author: 
>   INET: [EMAIL PROTECTED]
> 
> Fat City Network Services    -- (858) 538-5051  FAX: (858) 538-5051
> San Diego, California        -- Public Internet access / Mailing Lists
> --------------------------------------------------------------------
> To REMOVE yourself from this mailing list, send an E-Mail message
> to: [EMAIL PROTECTED] (note EXACT spelling of 'ListGuru') and in
> the message BODY, include a line containing: UNSUB ORACLE-L
> (or the name of mailing list you want to be removed from).  You may
> also send the HELP command for other information (like subscribing).

-- 
Please see the official ORACLE-L FAQ: http://www.orafaq.com
-- 
Author: =?iso-8859-8?Q?=E0=E3=F8_=E9=E7=E9=E0=EC?=
  INET: [EMAIL PROTECTED]

Fat City Network Services    -- (858) 538-5051  FAX: (858) 538-5051
San Diego, California        -- Public Internet access / Mailing Lists
--------------------------------------------------------------------
To REMOVE yourself from this mailing list, send an E-Mail message
to: [EMAIL PROTECTED] (note EXACT spelling of 'ListGuru') and in
the message BODY, include a line containing: UNSUB ORACLE-L
(or the name of mailing list you want to be removed from).  You may
also send the HELP command for other information (like subscribing).
--
Please see the official ORACLE-L FAQ: http://www.orafaq.com
--
Author:
  INET: [EMAIL PROTECTED]

Fat City Network Services    -- (858) 538-5051  FAX: (858) 538-5051
San Diego, California        -- Public Internet access / Mailing Lists
--------------------------------------------------------------------
To REMOVE yourself from this mailing list, send an E-Mail message
to: [EMAIL PROTECTED] (note EXACT spelling of 'ListGuru') and in
the message BODY, include a line containing: UNSUB ORACLE-L
(or the name of mailing list you want to be removed from).  You may
also send the HELP command for other information (like subscribing).

Reply via email to