Oracle普通用户密码验证和通过网络连接验证

本文介绍了Oracle数据库中用户管理的具体操作,包括如何修改用户名、密码及必要的系统操作以确保更改生效。此外还探讨了SYSDBA用户的身份验证流程及密码文件的作用。

普通用户采用的是数据字典的验证方式:

 select username,password from dba_users;

查看视图dba_users的源代码发现视图的主表来自于user$,我们在提交alter user XX identified by XX时,修改的就是这个表里的密码,然而有一点需要注意的是,如果修改完用户的名字,必须得将更改强制写回到数据文件中 alter system checkpoint;  ,并清除缓存里的数据字典信息才能生效 alter system flush shared_pool;

实验如下:

SQL> update user$ set name='SCOTT' where user#=54;

已更新 1 行。

SQL> commit;

提交完成。

SQL> select name from user$ where user#=54;

NAME
------------------------------
SCOTT

SQL> alter user scott identified by tiger;
alter user scott identified by tiger
           *
第 1 行出现错误:
ORA-01918: 用户 'SCOTT' 不存在

 

SQL> alter system checkpoint;

系统已更改。
SQL> alter user scott identified by tiger;
alter user scott identified by tiger
           *
第 1 行出现错误:
ORA-01918: 用户 'SCOTT' 不存在

SQL> alter system flush shared_pool;

系统已更改。

SQL> alter user scott identified by tiger;

用户已更改。

 

以SYSDBA身份通过网络连接数据库时需要通过密码文件的验证

密码文件保存了一个用户名和密码列表,这些用户名和密码分别对应于可以通过网络远程认证为SYSDBA 的用户。Oracle 必须使用这个文件来认证用户,而不是数据库中存储的正常密码列表。

查看口令文件中的用户命令:select * from v$pwfile_users;

当授予某用户SYSDBA权限时密码文件会自动添加一条新条目,并且会保持同步,当更改该用户的密码时密码文件也会自动更改(注意:若不是以SYSDBA身份登陆,即使是通过网络连接也用走的是普通用户验证路线)

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值