Oracle 12c 一次性解锁所有锁定的用户

Posted

技术标签:

【中文标题】Oracle 12c 一次性解锁所有锁定的用户【英文标题】:Oracle 12c UNLOCK ALL LOCKED users in one shot 【发布时间】:2020-07-07 17:50:55 【问题描述】:

您好,我想从我的 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

有什么想法吗? 还是我必须为每个用户手动操作?

【问题讨论】:

【参考方案1】:

一种选择是编写一个查询,它将为您编写查询。例如:

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>

【讨论】:

以上是关于Oracle 12c 一次性解锁所有锁定的用户的主要内容,如果未能解决你的问题,请参考以下文章

Oracle数据库老是被锁表,而且用解锁语句解开后,紧跟着又出来一堆锁,解也解不完

oracle数据库 账号为啥被锁了

Weblogic 用户自助解锁的2种方式试验

Oracle账号被锁定如何解锁

ORACLE 如何查询被锁定表及如何解锁释放session

oracle 用户被锁定解锁方法