ORA-28001: the password has expired解决方法

今天访问正式库,发现软件怎么都进不去,然后一行一行debug确定是数据库的问题,oracle有密码期限机制,附上我的解决方案:

 

 

今天发现服务器上的Oracle11g突然登录不上去了,提示ORA-28002错误,说是口令过期。


1. 用DBA账户登录SQL PLUS。我用的是SYS。
2. 系统会提示口令失效,但是会马上让你重置新密码。
3. 重置之后,进入SQL PLUS控制台。
4. 查看口令失效用户的profile文件

SQL>SELECT username,profile FROM dba_users;

EM(Web界面的控制台):服务器>用户,查看口令失效的用户对应的概要文件,这里假设为DEFAULT,下同。

5.查看对应的概要文件的口令有效期设置

SQL>SELECT * FROM dba_profiles WHERE profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME';

EM(Web界面的控制台):服务器>概要文件>选择刚刚查到的概要文件DEFAULT>查看,查看口令下面的有效期值。

6.将口令有效期默认值180天修改成“无限制”(此项要慎重!除非你真得不想要这个密码失效的机制!)

SQL>ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;

EM:服务器>概要文件>选择刚刚查到的概要文件DEFAULT>编辑>口令,在有效期输入或选择你需要的值,保存。

该参数修改实时生效。

出于数据库安全性考虑,不建议将PASSWORD_LIFE_TIME值设置成UNLIMITED,即建议客户能够定期修改数据库用户口令。

 

在修改PASSWORD_LIFE_TIME值之前已经失效的用户,还是需要重新修改一次密码才能使用。

SQL>ALTER USER test IDENTIFIED BY password
记住一共执行四行:

 

 转载自:https://www.cnblogs.com/xqzt/p/5637043.html?wework_cfm_code=NQDnPrOdXLZIEZiLbYRZC6K88aKogS%2Fcz2d5KEgssrxKxoTx8nFqu7uEuvVzt%2BcnTCOfqSMzQnu%2FSMwvCLBizV8%2F2q01bNEj8i3yF6jXctio

posted @ 2021-06-29 14:04  苏州の酱醋茶  阅读(887)  评论(0编辑  收藏  举报