簡體   English   中英

Oracle 12c 一次性解鎖所有鎖定的用戶

[英]Oracle 12c UNLOCK ALL LOCKED users in one shot

嗨,我想從我的 Oracle 12C 的 dba_users 中解鎖用戶列表。

我試過喜歡:

ALTER USER (SELECT username FROM dba_users WHERE ACCOUNT_STATUS LIKE '%LOCKED%') ACCOUNT UNLOCK;

ERROR at line 1:
ORA-01935: missing user or role name

任何想法? 或者我必須為每個用戶手動做?

一種選擇是編寫一個查詢,它將為您編寫查詢。 例如:

SQL> select 'alter user ' || username || ' account unlock;' from dba_users;

'ALTERUSER'||USERNAME||'ACCOUNTUNLOCK;'
---------------------------------------------------------
alter user SUPERUSER account unlock;
alter user C##TEST account unlock;
alter user SYS account unlock;
alter user SYSTEM account unlock;
alter user ANONYMOUS account unlock;
alter user SUSHANT account unlock;
alter user SCOTT account unlock;
<snip>

現在,復制/粘貼上述一堆ALTER USER語句,您將解鎖所有人。


另一個是使用動態 SQL 的簡單 PL/SQL 塊(我只解鎖用戶 SCOTT;你可以解鎖任何你想要的人)。

SQL> begin
  2    for cur_r in (select username from dba_users where username in ('SCOTT')) loop
  3      execute immediate 'alter user ' || cur_r.username || ' account unlock';
  4    end loop;
  5  end;
  6  /

PL/SQL procedure successfully completed.

SQL>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM