小程序容器助力企业在金融与物联网领域实现高效合规运营,带来的新机遇与挑战如何管理?
392
2023-12-11
这篇文章主要讲解了“Oracle的数据字典是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle的数据字典是什么”吧!
数据字典是oracle存放有关数据库信息的地方,几乎所有的系统信息和对象信息都可在数据字典中进行查询。数据字典是oracle数据库系统的信息核心,它是一组提供有关数据库信息的表和视图的集合,这些表和视图是只读的。它是随着数据库的建立而建立的,当数据库执行特定动作时数据字典也会自动更新。数据一览与数据字典来记录、校验和管理正在进行的操作。
Oracle中,sys用户是数据字典的拥有者,数据字典保证在所有数据库的系统表空间system内,任何用户都无权更改sys模式下的模式对象或数据字典中的行。也就是说数据字典只能查询,不能手动进行修改。
一、数据字典用途
Oracle通过存取数据字典从而比较方便地获取有关用户某事对象和存储结构等信息。当系统执行了DDL语句后,oracle会及时修改数据字典。任何用户只能以读的形式使用数据字典获取数据库信息。
二、数据字典存储的信息
数据用户的名称
为用户授予的权限和角色
模式对象的名。
完整性约束的具体信息;
每个字段的默认值;
数据库空间的使用情况;
存储审计的信息
对象与用户的严格管理(适用于高度机密管理);
其他一般数据库信息
三、四种前缀的数据字典视图
user_ :任何用户都可以读取的视图,每个用户读取的都不一样,它只提供当前用户某事下的对象信息。
如查询当前模式下的所有对象:
select object_name, object_type fromuser_objects;
all_ :所有用户都可读取的用户视图,它提供与用户有关的对象信息。
如查询当前用户可访问的所有对象:
select owner, object_name, object_type fromall_objects;
dba_:提供了只有数据库管理员才可读取的视图,包括所有用户视图中的对象信息。
如:
select owner, object_name, object_type fromsys.dba_objects;
v$:动态性能视图
动态性能视图用于记录当前例程的活动信息,当启动oracle server时,系统会建立动态性能视图;当停止oracle server时,系统会删除动态性能视图,oracle的所有动态性能视图都是以v_KaTeX parse error: Expected EOF, got 开 at position 1: 开̲始的,并且oracle为每个动…开始的,例如_KaTeX parse error: Expected EOF, got 的 at position 9: datefile的̲同义词为vdatefile;动态性能视图的所有者为sys,一般情况下,由DBA或是特权用户来查询动态性能视图。
四、查询数据字典示例
查询用户相关的数据字典
查询用户
select username fromdba_users; -- 只有管理员权限的用户才能查询
select username fromall_users; -- 当前或任何用户都可使用
-- 查看当前用户的默认表空间
select username, default_tablespace fromuser_users;
--当前用户角色
select * fromuser_role_privs;
-- 当前用户的系统权限和表级权限
select * fromuser_sys_privs;
select * fromuser_tab_privs;
查询表空间相关的数据字典(拥有DBA权限的用户才能查询)
select * fromdba_data_files;
select * fromdba_tablespaces; --表空间
selecttablespace_name, sum(bytes), sum(blocks)from dba_free_space group bytablespace_name; --空闲表空间
select * from dba_data_files where tablespace_name=USERS; -- 表空间对于的数据文件
select * from dba_segments where tablespace_name=USERS;
--查询用户模式对象所使用过的正在使用空间大小
select name, type, source_size, code_size fromuser_object_size;
查询数据库对象(拥有DBA权限的用户才能查询)
select * fromdba_objects
select * from dba_objects where object_type = upper(package body);
select * fromdba_objectswhere OBJECT_TYPE=TABLE and OWNER=SCOTT感谢各位的阅读,以上就是“Oracle的数据字典是什么”的内容了,经过本文的学习后,相信大家对Oracle的数据字典是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~