Oracle用户密码过期的根本原因,还是在于该用户所属的profile的life_time到期
总体思路## 1.查看该用户的过期时间,profile select username,expiry_date,profile from dba_users where username = 'ZXY'; ## 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 ZXY identified by newpassword;1.查看用户所属profile及过期时间
SYS@helowin>select username,expiry_date,profile from dba_users where username = 'ZXY'; USERNAME EXPIRY_DATE PROFILE ------------------------------ ------------------- ------------------------------ ZXY 2022-05-20 02:28:28 DEFAULT_ZXY
可以看到整个用户会在2022-05-20 02:28:28时候失效
2. 查看该profile的有效时长这里的DEFAULT_ZXY就是上一步通过用户名从dba_users中查出的PROFILE的值
SYS@helowin>select * from dba_profiles s where s.profile = 'DEFAULT_ZXY' and resource_name = 'PASSWORD_LIFE_TIME'; PROFILE RESOURCE_NAME RESOURCE LIMIT ------------------------------ -------------------------------- -------- ---------------------------------------- DEFAULT_ZXY PASSWORD_LIFE_TIME PASSWORD 30
可以看到还有30天到期
3.将该profile设置为永不过期将密码设置为永不过期后,可以通过前两步做校验,这里已经成功设置为永不过期
SYS@helowin>alter profile DEFAULT_ZXY limit password_life_time unlimited; Profile altered. SYS@helowin>select username,expiry_date,profile from dba_users where username = 'ZXY'; USERNAME EXPIRY_DATE PROFILE ------------------------------ ------------------- ------------------------------ ZXY DEFAULT_ZXY SYS@helowin>select * from dba_profiles s where s.profile = 'DEFAULT_ZXY' and resource_name = 'PASSWORD_LIFE_TIME'; PROFILE RESOURCE_NAME RESOURCE LIMIT ------------------------------ -------------------------------- -------- ---------------------------------------- DEFAULT_ZXY PASSWORD_LIFE_TIME PASSWORD UNLIMITED SYS@helowin>4.重置密码
如果你的密码已经过期了,那么需要你重新设置一下密码,无需重启数据库就会生效
alter user ZXY identified by zxy;5.其余相关命令
## 创建profile并设置过期时间30天 create profile default_zxy limit password_life_time 30; ## 创建profile并设置永不过期 create profile default_zxy limit password_life_time unlimited ## 为用户指定profile归属 alter user ZXY profile default_zxy



