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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容