Oracle密码过期 ORA-28002:口令将过期 解决方法

登录Pl/sql或导出数据时,得到的提示信息:

UDE-28002: 操作产生了 Oracle 错误 28002
ORA-28002: the password will expire within 7 days

 原因:oracle11g中默认在default概要文件中设置了"PASSWORD_LIFE_TIME=180”所导致,oracle用户的密码必须在180天内更改,否则启动数据库的时候会提示连接失败.

 解决办法

使用具有管理权限的用户登录


1、查看用户的proifle是哪个,一般是default:

SELECT username,PROFILE FROM dba_users;

一般都是默认的default

2、查看指定概要文件(如default)的密码有效期设置:
sql>

SELECT * FROM dba_profiles s WHERE s.profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME';

没改之前,这个位置是“180”


或者:

sql>

SELECT * FROM dba_profiles WHERE resource_name='PASSWORD_LIFE_TIME';

3、将密码有效期由默认的180天修改成“无限制”:


sql>

ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;

直接执行即可

注:修改之后不需要重启动数据库,会立即生效

4、注意:如果该数据库尚未提示“ORA 28002”,那么到上一步就可以了,以后也不会再提示。

  但是,如果数据库已经提示“ORA 28002”,现在需要给数据库重新设置一下密码,可以使用原来的密码,修改了密码之后就以后就不会再提示“ora 28002”了。

  使用如下sql更改密码。

alter user FYGAS72 identified by FYGAS72;  

  第一个“FYGAS72”是数据库用户名,第二个“FYGAS72”是新设置的密码。

 
 
原文地址:https://www.cnblogs.com/luxd/p/7410357.html