-- Description : Displays the DDL for a specific user.
  
  -- -----------------------------------------------------------------------------
  ------
  -- Author       : aws-senior.com
  -- Description  : Displays the DDL for a specific user.
  -- Call Syntax  : @user_ddl (username)
  -- -----------------------------------------------------------------------------
  ------
  
  set long 20000 longchunksize 20000 pagesize 0 linesize 1000 feedback off verify
  off trimspool on
  column ddl format a1000
  
  begin
     dbms_metadata.set_transform_param (dbms_metadata.session_transform, 'SQLTERMI
  NATOR', true);
     dbms_metadata.set_transform_param (dbms_metadata.session_transform, 'PRETTY',
   true);
  end;
  /
  
  variable v_username VARCHAR2(30);
  
  exec :v_username := upper('&1');
  
  select dbms_metadata.get_ddl('USER', u.username) AS ddl
  from   dba_users u
  where  u.username = :v_username
  union all
  select dbms_metadata.get_granted_ddl('TABLESPACE_QUOTA', tq.username) AS ddl
  from   dba_ts_quotas tq
  where  tq.username = :v_username
  and    rownum = 1
  union all
  select dbms_metadata.get_granted_ddl('ROLE_GRANT', rp.grantee) AS ddl
  from   dba_role_privs rp
  where  rp.grantee = :v_username
  and    rownum = 1
  union all
  select dbms_metadata.get_granted_ddl('SYSTEM_GRANT', sp.grantee) AS ddl
  from   dba_sys_privs sp
  where  sp.grantee = :v_username
  and    rownum = 1
  union all
  select dbms_metadata.get_granted_ddl('OBJECT_GRANT', tp.grantee) AS ddl
  from   dba_tab_privs tp
  where  tp.grantee = :v_username
  and    rownum = 1
  union all
  select dbms_metadata.get_granted_ddl('DEFAULT_ROLE', rp.grantee) AS ddl
  from   dba_role_privs rp
  where  rp.grantee = :v_username
  and    rp.default_role = 'YES'
  and    rownum = 1
  union all
  select to_clob('/* Start profile creation script in case they are missing') AS d
  dl
  from   dba_users u
  where  u.username = :v_username
  and    u.profile <> 'DEFAULT'
  and    rownum = 1
  union all
  select dbms_metadata.get_ddl('PROFILE', u.profile) AS ddl
  from   dba_users u
  where  u.username = :v_username
  and    u.profile <> 'DEFAULT'
  union all
  select to_clob('End profile creation script */') AS ddl
  from   dba_users u
  where  u.username = :v_username
  and    u.profile <> 'DEFAULT'
  and    rownum = 1
  /
  
  set linesize 80 pagesize 14 feedback on trimspool on verify on
  
  
  --------------------------------------------------------------------------------------
  -- File Name    : https://github.com/Zaalouni/OracleDba  
  -- Author       : Zaalouni
  -- website      : www.aws-senior.com
  -- Github       : https://github.com/Zaalouni/OracleDba 
  --------------------------------------------------------------------------------------
  
aws-senior.com
 
  www.aws-senior.comVisite out website www.aws-senior.com
http://www.aws-senior.com
www.aws-senior.com

 
 welcome to Aws-senior.com
welcome to Aws-senior.com 
Aucun commentaire:
Enregistrer un commentaire