20_数据字典.ppt_第1页
20_数据字典.ppt_第2页
20_数据字典.ppt_第3页
20_数据字典.ppt_第4页
20_数据字典.ppt_第5页
已阅读5页,还剩31页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Oracle中的数据字典,单世民,概述,数据字典用于存放有关数据库描述信息的数据。比如一个表的创建者信息,创建时间信息,所属表空间信息,用户访问权限信息等。当用户在对数据库中的数据进行操作时遇到困难就可以访问数据字典来查看详细的信息。,概述,基本的数据字典表由sys用户所有,并且保存在system表空间中。用户不能直接访问这些表,只能通过一系列视图访问数据字典表中的信息。,有效地利用数据字典,dictionary全部数据字典表的名称和解释,它有一个同义词dict dict_columns全部数据字典表里字段名称和解释,有效地利用数据字典,如果我们想查询跟索引有关的数据字典时,可以用下面这条SQ

2、L语句:,SELECT * FROM DICTIONARY WHERE INSTR(comments,index)0;,有效地利用数据字典,如果我们想知道user_indexes表各字段名称的详细含义,可以用下面这条SQL语句:,SELECT column_name,comments FROM DICT_COLUMNS WHERE table_name=USER_INDEX;,数据字典的分类,Oracle中的数据字典有静态和动态之分。静态数据字典主要是在用户访问数据字典时不会发生改变的,但动态数据字典是依赖数据库运行的性能的,反映数据库运行的一些内在信息,所以在访问这类数据字典时往往不是一成不

3、变的。,静态数据字典,这类数据字典主要是由表和视图组成,应该注意的是,数据字典中的表是不能直接被访问的,但是可以访问数据字典中的视图。静态数据字典中的视图分为三类,它们分别由三个前缀够成: user_* all_* dba_*,静态数据字典,user_*该视图存储了关于当前用户所拥有的对象的信息。(即所有在该用户模式下的对象),静态数据字典,all_*该视图存储了当前用户能够访问的对象的信息。(与user_*相比,all_* 并不需要拥有该对象,只需要具有访问该对象的权限即可),静态数据字典,dba_*该视图存储了数据库中所有对象的信息。(前提是当前用户具有访问这些数据库的权限,一般来说必须具

4、有管理员权限),静态数据字典,三者之间存储的数据有重叠,除了访问范围的不同以外,其他均具有一致性。具体来说,数据字典视图是由SYS(系统用户)所拥有的,所以在缺省情况下,只有SYS和拥有DBA系统权限的用户可以看到所有的视图。没有DBA权限的用户只能看到user_*和all_*视图。如果未被授予相关的SELECT权限的话,他们不能看到 dba_*视图。,常用user_*视图(目录和对象),user_tables视图主要描述当前用户拥有的所有表的信息,主要包括表名、表空间名、簇名等。通过此视图可以清楚了解当前用户可以操作的表有哪些。,SELECT * FROM USER_TABLES,对于外部表

5、可以查看user_external_tables和user_external_locations视图,常用user_*视图(目录和对象),user_tab_columns查看有关列的详细信息 user_tab_col_statistics查看列的统计信息 user_views查看用户定义视图的相关信息 user_synonyms查看用户定义同义词的相关信息 user_sequences查看用户定义序列的相关信息,常用user_*视图(目录和对象),user_catalog视图显示用户拥有的所有表、视图、同义词和序列,SELECT * FROM USER_CATALOG;,常用user_*视图(

6、目录和对象),user_objects视图主要描述当前用户拥有的所有对象的信息,对象包括表、视图、存储过程、触发器、包、索引、序列等。该视图比user_tables视图更加全面。,SELECT OBJECT_TYPE, STATUS FROM USER_OBJECTS WHERE OBJECT_NAME=UPPER(package1);,常用user_*视图(回收站),user_recyclebin视图查看回收站中的当前对象,无论对象是否可以恢复或基对象是否被删除,都可以查看到基对象名称。,该视图没有all_版本!,常用user_*视图(约束和注释),user_constraints查看有关约

7、束的信息 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查看有关抽象数

8、据类型的信息 user_type_attrs查看有关数据类型的属性信息 user_type_methods,user_method_params查看定义类型的方法的方法名等信息 user_ref,user_coll_type,user_nested_tables,user_varrays, user_lobs all_directories查看有关目录对象的信息,all_directories视图没有user_版本!,常用user_*视图(触发器、过程、函数和程序包),user_triggers查看触发器信息 user_source查看数据库中过程、函数、程序包、程序包体的源代码 user_e

9、rrors查看SQL*Plus中的错误信息 user_object_size查看过程化对象在system表空间中的占用空间,常用user_*视图(空间分配和使用),user_tablespaces确定有权访问的表空间和每个表空间的默认存储参数 user_ts_quotas确定当前已分配给用户的表空间量和通过表空间可以使用的最大空间量 user_segments,user_extents确定段,区的存储状况 user_part_tables确定一个表示如何分区的,常用user_*视图(用户和权限),user_users视图主要描述当前用户的信息,主要包括当前用户名、帐户id、帐户状态、表空间名、

10、创建时间等。例如执行下列命令即可返回这些信息:,SELECT * FROM USER_USERS,常用user_*视图(用户和权限),user_tab_privs视图该视图主要是存储当前用户下对所有表的权限信息。为了了解当前用户对table1的权限信息,可以执行如下命令:,SELECT * FROM USER_TAB_PRIVS WHERE TABLE_NAME=UPPER(table1);,静态数据字典,前面的视图均为user_开头的,其实all_开头的也完全是一样的,只是列出来的信息是当前用户可以访问的对象而不是当前用户拥有的对象。对于dba_开头的需要管理员权限,其他用法也完全一样,动态

11、数据字典,Oracle包含了一些潜在的由系统管理员如SYS维护的表和视图,由于当数据库运行的时候它们会不断进行更新,所以称它们为动态数据字典(或者是动态性能视图)。这些视图提供了关于内存和磁盘的运行情况,所以只能对其进行只读访问而不能修改它们。,HIGH AVAILABILITY AND RECOVERABILITY,SPECIFIC TECHNOLOGIES,DATABASE AND INSTANCE PERFORMANCE,DATABASE AND INSTANCE CONFIGURATION,STATIC DATABASE AND INSTANCE INFORMATION,几个主要的动态性能视图,v$access该视图显示数据库中锁定的数据库对象以及访问这些对象的会话对象(session对象)。,几个主要的动态性能视图,v$active_instance该视图主要描述当前数据库下的活动的实例的信息。依然可

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论