Oracle SQL 学习笔记12- 数据字典

什么是数据字典

Oracle通过数据字典来管理和展现数据库信息,数据字典通常储存数据库的元数据,是数据库的“数据库”。通常说的数据字典由4部分组成【1】:

  • 内部RDBMS(X$)表
  • 数据字典表
  • 动态性能视图(V$)
  • 静态数据字典视图

也就是所谓的两表两视图

数据字典视图类型

由于X$表数据字典表通常不能直接被用户访问,所以这里只关注视图:动态性能视图(V$)和静态数据字典视图。

动态性能视图

动态性能视图记录了数据库运行时信息和统计数据,大部分动态性能视图被实时更新以及反映数据库当前状态。在数据库启动时,Oracle动态创建X$表,在此基础上,Oracle创建了GV$和V$视图,GV$即Global V$,除了一些特例外,每个V$都对应一个GV$。GV$产生是为了OPS/RAC环境的需要,每个V$都是基于GV$的,只是GV$多了INST_ID列来显示实例ID。动态视图不在表空间中,不保证一致性。

静态数据字典视图

正如前面提到的,X$表和数据字典表通常不能直接被用户访问,Oracle创建了静态数据字典视图来提供用户对于数据字典信息的访问,由于这些信息通常相对稳定,不能直接修改,所以被称为静态数据字典视图静态数据字典视图在创建数据库时由$ORACLE_HOME/rdbms/admin/catagory.sql脚本创建。

静态数据字典视图在表空间中,重启并不清空。

静态数据字典视图按照前缀的不同通常分成三类:

  • USER_:用户拥有的视图,即schema中的和你所拥有的对象信息
  • ALL_:你有权限访问的所有对象的信息
  • DBA_:数据库所有相关对象的信息,用于需要有 select any table 的权限才能访问

三类视图在本质上是为了实现权限控制。在Oracle数据库中,每个用户与方案(Schema)是对应的,Schema是用户所拥有的对象的集合。数据库通过Schema将不同用户的对象隔离开来,用户可以自由的访问自己的对象,但是要访问其他Schema对象就需要相关的授权。Oracle创建了静态数据字典视图来提供用户对于数据字典信息的访问。

使用数据字典总视图

DICTIONARY是数据字典名称视图。

SQL> DESCRIBE DICTIONARY;
 Name                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 TABLE_NAME                     VARCHAR2(30)
 COMMENTS                       VARCHAR2(4000)

例如:

SQL> SELECT *
  2  FROM dictionary
  3  WHERE table_name = 'USER_OBJECTS';

TABLE_NAME
------------------------------
COMMENTS
--------------------------------------------------------------------------------
USER_OBJECTS
Objects owned by the user

USER_OBJECTS 和 ALL_OBJECTS

USER_OBJECTS 反应了当前用户的所有对象。通过该视图,可以查询当前schema下所有对象的名称和类型,以及这个对象的创建时间、最后一次修改时间以及状态信息(valid 或者 invalid)。
例如:

SQL> SELECT object_name, object_type, created, status
FROM user_objects
ORDER BY object_type; 

OBJECT_NAME
--------------------------------------------------------------------------------
OBJECT_TYPE     CREATED   STATUS
------------------- --------- -------
LOGMNR_SESSION_EVOLVE$_PK
INDEX           15-AUG-09 VALID

LOGMNR_UID$_PK
INDEX           15-AUG-09 VALID

LOGMNRC_DBNAME_UID_MAP_PK
INDEX           15-AUG-09 VALID

Table 的信息

Table的信息可以从 _TABLES 视图中获得。

SQL> DESCRIBE user_tables;
 Name                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 TABLE_NAME                NOT NULL VARCHAR2(30)
 TABLESPACE_NAME                    VARCHAR2(30)
 CLUSTER_NAME                       VARCHAR2(30)
 IOT_NAME                       VARCHAR2(30)
 STATUS                         VARCHAR2(8)
 PCT_FREE                       NUMBER
 PCT_USED                       NUMBER
...

实例:

SQL> SELECT table_name
  2  FROM user_tables
  3  ;

TABLE_NAME
------------------------------
LOGMNR_PARAMETER$
LOGMNR_SESSION$
MVIEW$_ADV_WORKLOAD
MVIEW$_ADV_BASETABLE
MVIEW$_ADV_SQLDEPEND
MVIEW$_ADV_PRETTY

Column 的信息

列的信息可以通过 _TAB_COLUMNS 获得:

SQL> DESCRIBE USER_TAB_COLUMNS;
 Name                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 TABLE_NAME                NOT NULL VARCHAR2(30)
 COLUMN_NAME                   NOT NULL VARCHAR2(30)
 DATA_TYPE                      VARCHAR2(106)
 DATA_TYPE_MOD                      VARCHAR2(3)
 DATA_TYPE_OWNER                    VARCHAR2(30)
 DATA_LENGTH                   NOT NULL NUMBER
 DATA_PRECISION                     NUMBER
 DATA_SCALE                     NUMBER
 NULLABLE                       VARCHAR2(1)
 COLUMN_ID                      NUMBER
...

Constraints 的信息

Constraints 的信息可以通过两个视图获得:

  • _CONSTRAINTS:表的约束信息
  • _CONS_COLUMNS:约束的列的信息
SQL> DESCRIBE user_constraints;
 Name                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 OWNER                          VARCHAR2(30)
 CONSTRAINT_NAME               NOT NULL VARCHAR2(30)
 CONSTRAINT_TYPE                    VARCHAR2(1)
 TABLE_NAME                NOT NULL VARCHAR2(30)
 SEARCH_CONDITION                   LONG
 R_OWNER                        VARCHAR2(30)
 R_CONSTRAINT_NAME                  VARCHAR2(30)
 DELETE_RULE                        VARCHAR2(9)
...

查询contraints column信息

SQL> DESCRIBE user_cons_columns;
 Name                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 OWNER                     NOT NULL VARCHAR2(30)
 CONSTRAINT_NAME               NOT NULL VARCHAR2(30)
 TABLE_NAME                NOT NULL VARCHAR2(30)
 COLUMN_NAME                        VARCHAR2(4000)
 POSITION                       NUMBER

实例:

SQL> SELECT constraint_name, column_name
FROM user_cons_columns
WHERE table_name = 'EMPLOYEES'; 

Sequence 信息

DESCRIBE user_sequences

Synonym 信息

DESCRIBE user_synonyms;

SELECT *
FROM user_synonyms,

View 信息

DESCRIBE user_views

SELECT DISTINCT view_name FROM user_views;

SELECT text FROM user_views
WHERE view_name = 'EMP_DETAILS_VIEW';

【1】详解Oracle数据字典

你可能感兴趣的:(Oracle SQL 学习笔记12- 数据字典)