20_数据字典.ppt
文本预览下载声明
Oracle中的数据字典 单世民 概述 数据字典用于存放有关数据库描述信息的数据。比如一个表的创建者信息,创建时间信息,所属表空间信息,用户访问权限信息等。当用户在对数据库中的数据进行操作时遇到困难就可以访问数据字典来查看详细的信息。 概述 基本的数据字典表由sys用户所有,并且保存在system表空间中。用户不能直接访问这些表,只能通过一系列视图访问数据字典表中的信息。 有效地利用数据字典 dictionary全部数据字典表的名称和解释,它有一个同义词dict dict_columns全部数据字典表里字段名称和解释 有效地利用数据字典 如果我们想查询跟索引有关的数据字典时,可以用下面这条SQL语句: 有效地利用数据字典 如果我们想知道user_indexes表各字段名称的详细含义,可以用下面这条SQL语句: 数据字典的分类 Oracle中的数据字典有静态和动态之分。静态数据字典主要是在用户访问数据字典时不会发生改变的,但动态数据字典是依赖数据库运行的性能的,反映数据库运行的一些内在信息,所以在访问这类数据字典时往往不是一成不变的。 静态数据字典 这类数据字典主要是由表和视图组成,应该注意的是,数据字典中的表是不能直接被访问的,但是可以访问数据字典中的视图。静态数据字典中的视图分为三类,它们分别由三个前缀够成: user_* all_* dba_* 静态数据字典 user_*该视图存储了关于当前用户所拥有的对象的信息。(即所有在该用户模式下的对象) 静态数据字典 all_*该视图存储了当前用户能够访问的对象的信息。(与user_*相比,all_* 并不需要拥有该对象,只需要具有访问该对象的权限即可) 静态数据字典 dba_*该视图存储了数据库中所有对象的信息。(前提是当前用户具有访问这些数据库的权限,一般来说必须具有管理员权限) 静态数据字典 三者之间存储的数据有重叠,除了访问范围的不同以外,其他均具有一致性。具体来说,数据字典视图是由SYS(系统用户)所拥有的,所以在缺省情况下,只有SYS和拥有DBA系统权限的用户可以看到所有的视图。没有DBA权限的用户只能看到user_*和all_*视图。如果未被授予相关的SELECT权限的话,他们不能看到 dba_*视图。 常用user_*视图(目录和对象) user_tables视图主要描述当前用户拥有的所有表的信息,主要包括表名、表空间名、簇名等。通过此视图可以清楚了解当前用户可以操作的表有哪些。 常用user_*视图(目录和对象) user_tab_columns 查看有关列的详细信息 user_tab_col_statistics 查看列的统计信息 user_views 查看用户定义视图的相关信息 user_synonyms 查看用户定义同义词的相关信息 user_sequences 查看用户定义序列的相关信息 常用user_*视图(目录和对象) user_catalog视图显示用户拥有的所有表、视图、同义词和序列 常用user_*视图(目录和对象) user_objects视图主要描述当前用户拥有的所有对象的信息,对象包括表、视图、存储过程、触发器、包、索引、序列等。该视图比user_tables视图更加全面。 常用user_*视图(回收站) user_recyclebin视图查看回收站中的当前对象,无论对象是否可以恢复或基对象是否被删除,都可以查看到基对象名称。 常用user_*视图(约束和注释) user_constraints 查看有关约束的信息 user_cons_columns 查看与约束相关的列信息(可以使用 从user_constraints视图获得的约束信息) user_tab_comments 查看表注释 user_col_comments 查看列注释 常用user_*视图(索引和群集) user_indexes 查看索引相关信息 user_ind_columns 查看索引有关列的信息 user_join_columns 查看位图连接索引的信息 user_cluster 查看与群集相关的存储和统计信息 user_clu_columns 查看表列到群集列的映射 常用user_*视图(抽象数据类型) user_types 查看有关抽象数据类型的信息 user_type_attrs 查看有关数据类型的属性信息 user_type_methods,user_method_params 查看定义类型的方法的方法名等信息 user_ref,user_coll_t
显示全部