处理字典值是把字典放内存还是用sql处理_高级SQL之数据字典

点击蓝字关注我吧

【本文详细介绍了数据库中数据字典的基本概念和用途等内容,欢迎读者朋友们阅读、转发和收藏!】

1 基本概念

数据字典 ( data dictionary )是对于数据模型中的数据对象或者项目的描述的集合,这样做有利于程序员和其他需要参考的人。分析一个用户交换的对象系统的第一步就是去辨别每一个对象,以及它与其他对象之间的关系。这个过程称为数据建模,结果产生一个对象关系图。当每个数据对象和项目都给出了一个描述性的名字之后,它的关系再进行描述(或者是成为潜在描述关系的结构中的一部分),然后再描述数据的类型(例如文本还是图像,或者是二进制数值),列出所有可能预先定义的数值,以及提供简单的文字性描述。这个集合被组织成书的形式用来参考,就叫做数据字典。

当开发用到数据模型的程序时,数据字典可以帮助你理解数据项适合结构中的哪个地方,它可能包含什么数值,以及数据项基本上表示现实世界中的什么意思。例如,一家银行或者是一个银行组织可能对客户银行业涉及的数据对象进行建模。他们需要给银行程序员提供数据字典。这个数据字典就描述了客户银行业中的数据模型每一个数据项(例如, “ 账户持有人 ” 和 “ 可用信用 ” )。

1.1 数据字典作用

数据字典最重要的作用是作为分析阶段的工具。任何字典最重要的用途都是供人查询对不了解的条目的解释,在 结构化分析 中,数据字典的作用是给数据流图上每个成分加以定义和说明。换句话说,数据流图上所有的成分的定义和解释的文字集合就是数据字典,而且在数据字典中建立的一组严密一致的定义很有助于改进分析员和用户的通信。

数据库数据字典不仅是每个数据库的中心,而且对每个用户也是非常重要的信息。用户可以用 SQL 语句访问数据库数据字典。

1.2 数据字典分类

数据字典在需求分析阶段被建立。

数据字典是一个预留空间,一个数据库,这是用来 储存 信息数据库本身。

数据字典可能包含的信息,例如:

Ø 数据库设计资料

Ø 储存的 SQL 程序

Ø 用户权限

Ø 用户统计

Ø 数据库的过程中的信息

Ø 数据库增长统计

Ø 数据库性能统计

数据字典则是系统中各类数据描述的集合,是进行详细的 数据收集 和数据分析所获得的主要成果。

数据字典通常包括 数据项 \ 数据结构 \ 数据流 \ 数据存储 和处理过程五个部分。

其中数据项是数据的最小组成单位若干个数据项可以组成一个数据结构数据字典通过对数据项和数据结构的 定义来描述数据流、数据存储的逻辑内容。

数据字典是关于数据的信息的集合,也就是对 数据流图 中包含的所有元素的定义的集合 .

数据字典还有另一种含义,是在 数据库设计 时用到的一种工具,用来描述数据库中基本表的设计,主要包括 字段名 、数据类型、主键、 外键 等描述表的属性的内容。

以 Oracle 数据库字典为例:数据字典分为数据字典表和数据字典视图

Oracle 数据库字典通常是在创建和安装数据库时被创建的, Oracle 数据字典是 Oracle 数据库系统工作的基础,没有数据字典的支持, Oracle 数据库系统就不能进行任何工作。数据字典中的表是不能直接被访问的,但是可以访问数据字典中的视图。

数据字典表里的数据是 Oracle 系统存放的系统数据,而普通表存放的是用户的数据。为了方便的区别这些表,这些表的名字都是用 "$" 结尾,这些表属于 SYS 用户。

数据字典表由 $
ORACLE_HOME/rdbms/admin/sql.bsq 脚本创建, 这个脚本里又调用了其他的脚本来创建这些数据字典表。在那些创建脚本里有基表的创建 SQL 。

Oracle 对数据字典表的说明:

These underlying tables store information about the database. Only Oracle Database should write to and read these tables. Users rarely access the base tables directly because they are normalized and most data is stored in a cryptic format.

这些数据字典表,只有 Oracle 能够进行读写。

SYS 用户下的这些数据字典表,存放在 system 表空间下面,表名都用 "$" 结尾,为了便于用户对数据字典表的查询, Oracle 对这些数据字典都分别建立了用户视图,这样即容易记住,还隐藏了数据字典表表之间的关系, Oracle 针对这些对象的范围,分别把视图命名为 DBA_XXXX, ALL_XXXX 和 USER_XXXX 。

数据字典视图分 2 类:静态数据字典(静态性能视图) 和 动态数据字典(动态性能视图)。

静态数据字典中的视图分为三类,它们分别由三个前缀构成:user_* 、 all_* 、 dba_* 。

  • user_* :该视图存储了关于当前用户所拥有的对象的信息。(即所有在该用户模式下的对象)

  • all_* :该视图存储了当前用户能够访问的对象的信息 , 而不是当前用户拥有的对象。(与 user_* 相比, all_* 并不需要拥有该对象,只需要具有访问该对象的权限即可)

  • dba_* :该视图存储了数据库中所有对象的信息。(前提是当前用户具有访问这些数据库的权限,一般来说必须具有管理员权限)

这些视图由 SYS 用户创建的,所以使用需要加上 SYS, 为了方便, Oracle 为每个数据字典表的视图头建立了同名字的公共同义词 (public synonyms). 这样简单的处理就省去了写 sys. 的麻烦。

除了静态数据字典中三类视图,其他的字典视图中主要的是 V$ 视图,之所以这样叫是因为他们都是以 V$ 或 GV$ 开头的。这些视图会不断的进行更新,从而提供了关于内存和磁盘的运行情况,所以我们只能对其进行只读访问而不能修改它们。

Throughout its operation, Oracle Database maintains a set of virtual tables that record current database activity. These views are calleddynamic performance views because they are continuously updated while a database is open and in use. The views, also sometimes calledV$ views 。

V$ 视图是基于 X$ 虚拟视图的。V$ 视图是 SYS 用户所拥有的,在缺省状况下,只有 SYS 用户和拥有 DBA 系统权限的用户可以看到所有的视图,没有 DBA 权限的用户可以看到 USER_ 和 ALL_ 视图,但不能看到 DBA_ 视图。与 DBA_,ALL, 和 USER_ 视图中面向数据库信息相反,这些视图可视的给出了面向实例的信息。

动态性能表用于记录当前数据库的活动,只存于数据库运行期间,实际的信息都取自内存和控制文件。DBA 可以使用动态视图来监视和调节数据。

1.3 数据字典的组成

数据字典的组成:

1 、数据项

2 、数据结构

3 、数据流

4 、数据存储

5 、处理过程

数据字典是数据库的重要组成部分。它存放有数据库所用的有关信息,对用户来说是一组只读的表。数据字典内容包括:

1 、数据库中所有模式对象的信息,如表、视图、簇、及索引等。

2 、分配多少空间,当前使用了多少空间等。

3 、列的 缺省值 。

4 、约束信息的完整性。

5 、用户的名字。

6 、用户及角色被 授予的权限 。

7 、用户访问或使用的审计信息。

8 、其它产生的数据库信息。

数据库数据字典是一组表和视图结构。它们存放在 SYSTEM 表空间 中。

数据库数据字典不仅是每个数据库的中心。而且对每个用户也是非常重要的信息。用户可以用 SQL 语句访问数据库数据字典。

关于数据的信息集合 , 是一种用户可以访问的记录数据库和应用程序元数据的目录 , 是对数据库内表信息的物理与逻辑的说明。

我知道你在看

e28bc931167d5b9dd0aca12b3b3b3995.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值