Oracle密码过期问题,设置永不过期
Oracle用户密码过期的根本原因,还是在于该用户所属的profile的life_time到期
总体思路
1.查看该用户的过期时间,profile
select username,expiry_date,profile from dba_users where username = 'ABC';
2.查看该profile的有效时长
SELECT * FROM dba_profiles s WHERE s.profile = 'DEFAULT' AND resource_name = 'PASSWORD_LIFE_TIME';
3.将该profile设置为永不过期
alter profile default limit password_life_time unlimited;
4.重新设置一下该用户的密码
alter user ABC identified by newpassword;
1.查看用户所属profile及过期时间
SYS@oracle>select username,expiry_date,profile from dba_users where username = 'ABC';
2. 查看该profile的有效时长
这里的DEFAULT_ABC就是上一步通过用户名从dba_users中查出的PROFILE的值
SYS@oracle>select * from dba_profiles s where s.profile = 'DEFAULT_ABC' and resource_name = 'PASSWORD_LIFE_TIME';
3.将该profile设置为永不过期
将密码设置为永不过期后,可以通过前两步做校验,这里已经成功设置为永不过期
SYS@oracle>alter profile DEFAULT_ABC limit password_life_time unlimited;
SYS@oracle>select username,expiry_date,profile from dba_users where username = 'ABC';
SYS@oracle>select * from dba_profiles s where s.profile = 'DEFAULT_ABC' and resource_name = 'PASSWORD_LIFE_TIME';
4.重置密码
如果你的密码已经过期了,那么需要你重新设置一下密码,无需重启数据库就会生效
alter user ABC identified by ABC;
5.其余相关命令
创建profile并设置过期时间30天
create profile default_ABC limit password_life_time 30;
创建profile并设置永不过期
create profile default_ABC limit password_life_time unlimited
为用户指定profile归属
alter user ABC profile default_ABC