什么是数据字典
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数据字典