SQL 21日自学通(V3.0)(PDF格式)-第65部分
按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!
系统工程师是有着创建和设计数据库的模块 应用程序的开发以及应用程序的管理任
务的用户 在一些公司中会使用另外一种称呼 如程序员 程序分析员 数据模块师来称
呼他们的系统工程师 系统工程师是直接地使用数据字典来管理和开发过程的 当访问一
个已经存在的工程的时候 访问也可以通过数据库前终应用程序 开发工具以及计算机工
程帮助工具来获得 对于这些用户来说常用的系统目录是查询处于他的计划组中的模块
查询应用任务及权限和查询模块开发情况的统计 在特定的计划中系统工程师也可以将数
据字典应用于系统工程师的专用对象上
数据库管理员 DBAS 是数据字典中所定义的具有最大权限的用户 与其它的两组
用户偶而也会使用系统目录不同 DBAS 将使用数据字典作为他们的日常工作 访问通常
是通过查询的 但也可以通过数据库管理工具如 ORACLE 的 SERVER MANGER DBA 使
用数据字典中的信息来管理用户和资源以达到数据库优化运行的目的
如你所见 所有的数据库用户都需要使用数据字典 更为重要的是 关系型数据库系
统没有数据字典就无法存在了
数据字典中的内容
这一部分使用两种关系型数据库系统的系统目录 Oracle 和 Sybase 的 尽管这两种数
329
…………………………………………………………Page 330……………………………………………………………
SQL 21 日自学通(V1。0) 翻译人 笨猪
据库系统都有着他自己的特点 但是他们提供的功能是相同的 不要关心它们在名字上的
不同 你只要明白数据字典的概念和它的内容就行了
Oracle 的数据字典
由于每一个表都必须有一个所有者 系统目录在数据字典中的所有者是 SYS Oracle
的数据字典可以分为三个基本类 用户访问视图 DBA 视图 以及动态执行表— — 它也会
以视图的形式出现 视图可以查询用户在数据字典中的用户账号信息 如权限和目录表的
创建 DBA 可以帮助数据库管理员完成日常的工作 它允许 DBA 来管理用户和数据库中
的其它对象 在 ORALCE 中的动态执行表也可以为 DBA 所使用并提供了对数据库的更深
层的监视 这些视图提供了储如对过程的执行 对 ROLLBACK 段的动态使用 内存的使
用等储如此类的统计信息 动态执行表都以 V为前缀
Sybase 的数据字典
与 ORACLE 一样 Sybase 中系统表的所有者也是 SYS 该表可以被分为两个部分
系统表和数据库表
系统表只能为数据库所有者所拥有 这些表定义的对象 如表和索引 为多个数据库
所共有 另一部分表在 Sybase SQL Server 中的称为数据库表 这些表只与每个特定的数据
库相关联
ORACLE 数据字典的内部结构
这一部分的例子会告诉你如何从数据字典中获得信息以及如何将它应用于广大关系型
数据库的用户也就是 最终用户 系统工程师和 DBA ORACLE 数据字典中有大量的关
于所有类型的数据库用户的表和视图 这是为什么我们要进一步研究 ORACLE 数据字典的
原因
用户视图
用户视图是在数据字典中的可以为全部用户所拥有的视图 一个用户对其它的用户只
有 CREATE SESSION 的权限 所有的用户都是这样
330
…………………………………………………………Page 331……………………………………………………………
SQL 21 日自学通(V1。0) 翻译人 笨猪
你是谁
在进行对数据库的无穷尽的知识的探险之前 你应该确切地知道你是谁 在数据库中
的字眼 和你能做什么 下边的两个例子中给出两个表中的 SELECT 语句 其中一个会告
诉你是谁而另一个会告诉你可以使用哪些数据库
INPUT
SQL》 SELECT * FROM USER_USERS
OUTPUT
USERNAME USER_ID DEFAULT_TABLESPACE TEMPORARY TABLESPACE CREATED
JSMITH 29 USERS TEMP 14…MAR…97
分析
USER_USERS 视图可以告诉你你在 ORACLE 中的 ID 是如何设置的 它也可以显示其
它用户的详细情况 以及对用户的统计 默认的表大小和临时表的大小也可以被显示 默
认的 USER 的表的大小是指由该用户所创建的表的大小 临时表大小是对 JSMITH 所指定
的进行排序和分组空间的大小
INPUT/OUTPUT
SQL》 SELECT * FROM ALL_USERS;
USERNAME USER_ID CREATED
SYS 0 01…JAN…97
SYSTEM 5 01…JAN…97
SCOTT 8 01…JAN…97
JSMITH 10 14…MAR…97
TJONES 11 15…MAR…97
VJOHNSON 12 15…MAR…97
正如你在上边的查询结果中所看到的那样 你可以使用 ALL_USERS 视图你可以看到
所有存在于数据库中的用户 但是 它不会给出像上边的那个视图那么详细的信息 因为
对于这一级用户来说是没有必要的 只有对于系统级用户才会需要更详细的信息
你有哪些权限
现在你已经知道你是谁了 如果你可以知道你能做什么就太好了 有好几个视图都可
以为你提供这样的信息 USER_SYS_PRIVS 视图和 USER_ROLE_PRIVS 视图可以给你最
331
…………………………………………………………Page 332……………………………………………………………
SQL 21 日自学通(V1。0) 翻译人 笨猪
为权威的信息
你可以使用 USER_SYS_PRIVS 来查看系统的权限 切记 系统权限是指你对于特定
数据库的整体权限 这些权限并不针对任何一个对象或对象集
INPUT
SQL》 SELECT * FROM USER_SYS_PRIVS;
OUTPUT
USERNAME PRIVILEGE ADM
JSMITH UNLIMITED TABLESPACE NO
JSMITH CREATE SESSION NO
分析
JSMITH 已经被赋予了两种系统级权限 除了获准的任务以外 请注意第二部分 创
建会话 CREATE SESSION 它包括在 ORACLE 的标准任务 CONNECT 这将会在下边
的例子中提到
你可以使用 USER_ROLE_PRIVS 视图来查看你在数据库中被允许的任务信息 数据库
任务与系统任务非常相似 当任务为权限所许可之后 可以将任务许可给该用户 切记
在任务中可能会有对象级权限
INPUT/OUTPUT
SQL》 SELECT * FROM USER_ROLE_PRIVS;
USERNAME GRANTED_ROLE ADM DEF OS_
JSMITH CONNECT NO YES NO
JSMITH RESOURCE NO YES NO
分析
USER_ROLE_PRIVS 视图可以让你查看允许你执行的任务 在早些时候曾经说过
CONNECT 包含着系统权限 CREATE SESSION 与其它的权限一样 RESOURCE 也有为
数不多的权限 你可以查看一下给予用户的缺省任务 用户不能将这些任务再给予其它的
用户 这对于 ADM 来说非常重要 而且该任务也不能为操作系统所允许 参见第 12 天
的 数据库安全
你可以访问哪些东西
现在你也许会问 我可以访问哪些内容呢 我已经知道了我是谁 我也知道了我的权
332
…………………………………………………………Page 333……………………………………………………………
SQL 21 日自学通(V1。0) 翻译人 笨猪
限 但是我在哪里可以将到我的数据 你可以通常查看在数据字典中的不同的可用用户视
图来回答这个问题 这一部分的内容对于一些视图来说很有帮助
也许最为基本的用户视图就是 USER_CATALOG 了 它是一个表 视图 同义字和当
前所有的次序的简明目录
INPUT
SQL》 SELECT * FROM USER_CATALOG;
OUTPUT
TABLE_NAME TABLE_TYPE
MAGAZINE_TBL TABLE
MAG_COUNTER SEQUENCE
MAG_VIEW VIEW
SPORTS TABLE
分析
这个例子中给出了为你所有的所有表和相关对象的清单 出于简明的目的你也可以使
用 USER_CATALOG 中的公共同义字 那就是 试一下 SELECT * FROM CAT
另外一个有用的视图是 ALL_CATALOG 它可以让你看到其他人拥有的表
INPUT/OUTPUT
SQL》 SELECT * FROM ALL_CATALOG;
OWNER TABLE_NAME TABLE_TYPE
SYS DUAL TABLE
PUBLIC DUAL SYNONYM
JSMITH MAGAZINE_TBL TABLE
JSMITH MAG_COUNTER SEQUENCE
JSMITH MAG_VIEW VIEW
JSMITH SPORTS TABLE
VJOHNSON TEST1 TABLE
VJOHNSON HOBBIES TABLE
VJOHNSON CLASSES TABLE
VJOHNSON STUDENTS VIEW
分析
作为用户你可以会拥有比上表更多的对象 系统表会加入许多的表 我们可以很容易
在将这个清单简化 ALL_CATALOG 视图与 the USER_CATALOG 视图一样 但是它显示
给你所有的你可以访问的表 视图 顺序 和同义字
333
…………………………………………………………Page 334……………………………………………………………
SQL 21 日自学通(V1。0) 翻译人 笨猪
INPUT
SQL》 SELECT SUBSTR(OBJECT_TYPE;1;15) OBJECT_TYPE;
2 SUBSTR(OBJECT_NAME;1;30) OBJECT_NAME;
3 CREATED;
4 STATUS
5 FROM USER_OBJECTS
6 ORDER BY 1;
OUTPUT
OBJECT_TYPE OBJECT_NAME CREATED STATUS
INDEX MAGAZINE_INX 14…MAR…97 VALID
INDEX SPORTS_INX 14…MAR…97 VALID
INDEX HOBBY_INX 14…MAR…97 VALID
TABLE MAGAZINE_TBL 01…MAR…97 VALID
TABLE SPORTS 14…MAR…97 VALID
TABLE HOBBY_TBL 16…MAR…97 VALID
分析
你可以使用 USER_OBJECTS 视图来获得关于用户所拥有对象的通用信息如名字 类
型 数据的创建 数据的更新以及对象的状态 在上一个查询中 我们对每一个数据对象
的创建进行了确认
INPUT/OUTPUT
SQL》 SELECT TABLE_NAME; INITIAL_EXTENT; NEXT_EXTENT
2 FROM USER_TABLES;
TABLE_NAME INITIAL_EXTENT NEXT EXTENT
MAGAZINE_TBL 1