oracle база данных 19 c - предоставить [имя роли] [пользователю] ошибка ORA-01917: пользователь или роль не существует - PullRequest
0 голосов
/ 26 мая 2020

Я использую этот сценарий для создания пользователя и роли для oracle базы данных 19 c и получаю ошибку ORA-01917


CREATE ROLE C##readonlyrole;

CREATE USER "C##lysjr_ro" IDENTIFIED BY "XXXXXXXPASWORD"  
DEFAULT TABLESPACE "XXX_TABLE_SPACE"
TEMPORARY TABLESPACE "XXX_TABLE_SPACE_TEMP";

GRANT CREATE SESSION to C##readonlyrole;

BEGIN
  FOR x IN (SELECT * FROM dba_tables WHERE owner='C##lysjr_ro')
  LOOP
    EXECUTE IMMEDIATE 'GRANT SELECT ON schema_name.' || x.table_name || 
                                  ' TO C##readonlyrole';
  END LOOP;
END;

GRANT C##readonlyrole TO C##lysjr_ro;

Но

GRANT C##readonlyrole TO C##lysjr_ro;

Показать отчет об ошибке с результат:

GRANT C##readonlyrole TO C##lysjr_ro
Error report -
ORA-01917: user or role 'C##lysjr_ro' does not exist
01917. 00000 -  "user or role '%s' does not exist"
*Cause:    There is not a user or role by that name.
*Action:   Re-specify the name.

что теперь делать?

1 Ответ

1 голос
/ 26 мая 2020

Попробуйте не , используя кавычки в вашей команде создания пользователя:

CREATE USER C##lysjr_ro IDENTIFIED BY XXXXXXXPASWORD  
DEFAULT TABLESPACE XXX_TABLE_SPACE
TEMPORARY TABLESPACE XXX_TABLE_SPACE_TEMP;
...