分类: ASP.NET+ORACLE 2010-08-29 22:40 2164人阅读 评论(0) 收藏 举报
来源:http://www.cnblogs.com/luohoufu/archive/2008/09/03/1282945.html
作用:想要生成整个Oracle数据库所有表结构WORD文档(数据库设计说明书)
Oracle数据库字典介绍
Oracle数据字典是有表和视图组成的,存储有关数据库结构信息的一些数据库对象。数据库字典描述了实际数据是如何组织的。对它们可以象处理其他数据库表或视图一样进行查询,但不能进行任何修改。
Oracle数据库字典通常是在创建和安装数据库时被创建的,Oracle数据字典是Oracle数据库系统工作的基础,没有数据字典的支持,Oracle数据库系统就不能进行任何工作。
在Oracle数据库字典中,许多视图都有三个不同的实例,它们的前缀分别为"USER_"、"ALL_"及"DBA_"。"USER_"为前缀的数据库字典视图通常记录执行查询的帐户所拥有的对象的信息,"ALL_"为前缀的数据库字典视图通常记录包括执行查询的帐户所拥有的对象的信息及授权至PUBLIC的帐户用户所拥有的对象的信息,"DBA_"为前缀的数据库字典视图则包含所有数据库对象的信息,而不管其所有者。其他的字典视图中主要的是V$视图,之所以这样叫是因为他们都是以V$或GV$开头的。V$视图是基于X$虚拟视图的。V$视图是SYS用户所拥有的,在缺省状况下,只有SYS用户和拥有DBA系统权限的用户可以看到所有的视图,没有DBA权限的用户可以看到USER_和ALL_视图,但不能看到DBA_视图。与DBA_,ALL,和USER_视图中面向数据库信息相反,这些视图可视的给出了面向实例的信息。
在Oracle的绝大多数数据字典视图中都有象DBA_TABLES,ALL_TABLES和USER_TABLES这样的视图家族。Oracle中有超过100个视图家族,下表列出了最重要和最常用的视图家族,需要注意的是每个视图家族都有一个DBA_,一个ALL_一个USER_视图。
视图家族
|
描述
|
COL_PRIVS
|
包含了表的列权限,包括授予者、被授予者和权限
|
EXTENTS
|
数据范围信息,比如数据文件,数据段名(segment_name)和大小
|
INDEXES
|
索引信息,比如类型、唯一性和被涉及的表
|
IND_COLUMNS
|
索引列信息,比如索引上的列的排序方式
|
OBJECTS
|
对象信息,比如状态和DDL time
|
ROLE_PRIVS
|
角色权限,比如GRANT和ADMIN选项
|
SEGMENTS
|
表和索引的数据段信息,比如tablespace和storage
|
SEQUECNCES
|
序列信息,比如序列的cache、cycle和ast_number
|
SOURCE
|
除触发器之外的所有内置过程、函数、包的源代码
|
SYNONYMS
|
别名信息,比如引用的对象和数据库链接db_link
|
SYS_PRIVS
|
系统权限,比如grantee、privilege、admin选项
|
TAB_COLUMNS
|
表和视图的列信息,包括列的数据类型
|
TAB_PRIVS
|
表权限,比如授予者、被授予者和权限
|
TABLES
|
表信息,比如表空间(tablespace),存储参数(storage parms)和数据行的数量
|
TRIGGERS
|
触发器信息,比如类型、事件、触发体(trigger body)
|
USERS
|
用户信息,比如临时的和缺省的表空间
|
VIEWS
|
视图信息,包括视图定义
|
在Oracle中还有一些不常用的数据字典表,但这些表不是真正的字典家族,他们都是一些重要的单一的视图。这些视图见下表:
视图名称
|
描述
|
USER_COL_PRIVS_MADE
|
用户授予他人的列权限
|
USER_COL_PRIVS_RECD
|
用户获得的列权限
|
USER_TAB_PRIVS_MADE
|
用户授予他人的表权限
|
USER_TAB_PRIVS_RECD
|
用户获得的表权限
|
Oracle数据库字典的应用
借助Oracle数据字典,利用Oracle的DDL语句,我们可以做很多事情,几乎所有的Oracle开发辅助工具都是利用这一点进行设计的。作者将通过如何取得数据库表字段信息来说明。
首先我们定义一个数据库表,数据库表结构如下:
数据库表名[TABLE_TEST]
|
字段名
|
数据类型
|
长度
|
缺省值
|
允许空
|
主键
|
注释
|
NAME
|
VARCHAR2
|
40
|
|
N
|
Y
|
姓名
|
SEX
|
VARCHAR2
|
1
|
''''Y''''
|
N
|
|
性别
|
BIRTHDAY
|
DATE
|
0
|
|
Y
|
|
生日
|
HEIGHT
|
NUMBER
|
3,1
|
|
Y
|
|
身高
|
WEIGHT
|
NUMBER
|
3,1
|
|
Y
|
|
体重
|
MEMO
|
BLOB
|
0
|
|
Y
|
|
备注
|
创建表的SQL语句如下
-- 创建数据表
create table TABLE_TEST
(
NAME varchar2(40) not null,
SEX varchar2(1) default ''''Y'''' not null,
BIRTHDAY date not null,
HEIGHT number(3,2),
WEIGHT number(3,2),
MEMO blob
);
-- 给列添加备注
comment on column TABLE_TEST.NAME is ''''姓名'''';
comment on column TABLE_TEST.SEX is ''''性别'''';
comment on column TABLE_TEST.BIRTHDAY is ''''生日'''';
comment on column TABLE_TEST.HEIGHT is ''''身高'''';
comment on column TABLE_TEST.WEIGHT is ''''体重'''';
comment on column TABLE_TEST.MEMO is ''''备注'''';
-- 创建约束关系 主键 外键 其他
alter table TABLE_TEST add constraint TB_TEST_P_NAME primary key (NAME);
数据表创建完毕,执行下列SQL语句:
select
A.column_name 字段名,A.data_type 数据类型,A.data_length 长度,A.data_precision 整数位,
A.Data_Scale 小数位,A.nullable 允许空值,A.Data_default 缺省值,B.comments 备注
from
user_tab_columns A,user_col_comments B
where
A.Table_Name = B.Table_Name
and A.Column_Name = B.Column_Name
and A.Table_Name = ''''TABLE_TEST''''
我们可以得出一下结果:
字段名
|
数据类型
|
长度
|
整数位
|
小数位
|
允许空值
|
缺省值
|
备注
|
NAME
|
VARCHAR2
|
40
|
|
|
N
|
<Long>
|
姓名
|
SEX
|
VARCHAR2
|
1
|
|
|
N
|
<Long>
|
性别
|
BIRTHDAY
|
DATE
|
7
|
|
|
N
|
<Long>
|
生日
|
HEIGHT
|
NUMBER
|
22
|
3
|
2
|
Y
|
<Long>
|
身高
|
WEIGHT
|
NUMBER
|
22
|
3
|
2
|
Y
|
<Long>
|
体重
|
MEMO
|
BLOB
|
4000
|
|
|
Y
|
<Long>
|
备注
|
这样,我们在进行程序设计时,通过一条简单的SQL语句,然好通过Ole调用Word,便可为最终用户导出完整的数据库表字典文档。
再执行下列SQL语句:
select
INDEX_NAME 索引名,INDEX_TYPE 索引类型,UNIQUENESS 索引类别
from
user_indexes
where
TABLE_NAME = ''''TABLE_TEST''''
得到结果如下(注:SYS_IL0000031226C00006$$索引为系统在创建数据库表时自动创建的,用于数据库表内容的维护):
|
索引名
|
索引类型
|
索引类别
|
1
|
SYS_IL0000031226C00006$$
|
LOB
|
UNIQUE
|
2
|
TB_TEST_P_NAME
|
NORMAL
|
UNIQUE
|
执行下列SQL语句,我们将得到更多的关于数据库表结构的信息:
select
A.column_name 字段名,A.data_type 数据类型,A.data_length 长度,A.data_precision 整数位,
A.Data_Scale 小数位,A.nullable 允许空值,A.Data_default 缺省值,B.comments 备注,
C.IndexCount 索引次数
from
user_tab_columns A,
user_col_comments B,
(select count(*) IndexCount,Column_Name from User_Ind_Columns where Table_Name = ''''TABLE_TEST'''' group by Column_Name) C
where
A.Table_Name = B.Table_Name
and A.Column_Name = B.Column_Name
and A.Column_Name = C.Column_Name(+)
and A.Table_Name = ''''TABLE_TEST''''
得到结果如下:
字段名
|
数据类型
|
长度
|
整数位
|
小数位
|
允许空值
|
缺省值
|
备注
|
索引次数
|
BIRTHDAY
|
DATE
|
7
|
|
|
N
|
<Long>
|
生日
|
|
HEIGHT
|
NUMBER
|
22
|
3
|
2
|
Y
|
<Long>
|
身高
|
|
MEMO
|
BLOB
|
4000
|
|
|
Y
|
<Long>
|
备注
|
|
NAME
|
VARCHAR2
|
40
|
|
|
N
|
<Long>
|
姓名
|
1
|
SEX
|
VARCHAR2
|
1
|
|
|
N
|
<Long>
|
性别
|
|
WEIGHT
|
NUMBER
|
22
|
3
|
2
|
Y
|
<Long>
|
体重
|
|
当然Oracle数据字典的应用远不止这些,通过Oracle数据库字典的支持,我们可以得到Oracle数据库结构的所有信息,著名的数据库开发工具PL/SQL Developer完全就是基于Oracle的数据库字典实现的。
分享到:
相关推荐
1. **表结构提取**:DBExport能够连接到Oracle数据库,读取指定用户下的所有表或选定表的信息,包括表名、字段名、字段类型、主键、外键等关键信息。 2. **自定义导出**:用户可以选择只导出特定的表,或者根据需要...
在数据库设计和文档编写过程中,需要对表结构进行详细记录,包括字段名、数据类型以及备注等信息。本文将探讨如何通过JAVA编程语言实现从Oracle数据库中提取这些信息,并将其格式化地写入到Word表格中,以自动化这一...
**4.1 数据关系图**:未提供图形,但可以推测与日记账导入相关的表结构。 **4.2 数据表简述** - **4.3.1 gl_interface**:日记账导入接口表,用于导入外部日记账数据到OracleEBS系统中。 #### 五、总结 Oracle...
该SQL可以直接导出oracle用户下的表结构信息,结果包含了表的字段基本信息,主键信息,以及字段备注信息等,经生产测试可用。sql脚本内容如下 --注:当前查询结果只包含 有主键字段的表结构信息 Select A.OWNER ...
### Oracle数据库数据查询相关知识 #### 实验四:表数据的插入、修改和删除 **实验目的** 1. **掌握PL/SQL语句对数据库表进行插入、修改和删除数据的操作**:通过实验,学生应能熟练运用PL/SQL语言进行表数据的...
这一步涉及复制Oracle数据库中的表结构,包括表名、字段、数据类型、主键、外键、唯一性约束、非空约束等,并在DM8中重建。同时,迁移索引以保持查询性能,以及字段的注释和序列,用于自增字段。 四、删除键,约束...
1,打开PowerDesigner,找到创建的物理模型(Physical Data Model), 2,使用快捷键,或者 在PowerDesigner菜单栏中,依次点击“Tools ->Excute Commands->Edit/Run Script..” ...4,将导出的结果(Excel)保存到自己的...
在Oracle数据库中,获取当前用户表、字段等详细信息是一项常见的需求,这有助于数据库管理员或开发者了解数据库结构,进行数据管理、分析或开发工作。本文将深入解析如何使用SQL语句来实现这一功能。 首先,我们...
3.查看表结构非常方便,同时对表的数据维护调试也非常得顺手; 4.修改TABLE名,VIEW名,COLUMN信息非常方便,最关键的是对它们的备注修改非常方便(对于View的字段备注的处理,某些知名软件甚至都没有提供); 5.能够...
3. 字段信息提取:工具能够读取表结构,包括字段名、数据类型、长度、默认值、是否允许为空等,并以清晰的格式展示在Word文档中。 4. 约束与索引:除了字段信息,工具还应包含表的主键、外键、唯一性约束和索引等...
CREATE TABLE语句用于定义表结构,包括列名、数据类型、默认值、约束等。例如,创建一个名为tab_student的表,包含sno(学生编号,主键)、sname(学生姓名,非空)、sbirth(出生日期)、sage(年龄,默认为0)、...
例如,创建名为T_GIRL的表,包含编号、姓名、颜值、身材、体重、身高、出生时间和备注等字段。 - 在创建表时,字段可以设置是否允许为空(NULL),通常主键字段不允许为空。 4. **主键**: - 主键是表中的一个或...
Oracle 数据库原理及应用 - 创建数据表与操作 数据库是存储、管理和检索数据的仓库,它是现代信息系统的核心组件之一。Oracle 是一种流行的关系数据库管理系统(RDBMS),广泛应用于企业信息系统、互联网应用和移动...
查看表结构非常方便,同时对表的数据维护调试也非常得顺手.4.修改TABLE名,VIEW名,COLUMN信息非常方便,最关键的是对它们的备注修改非常方便(对于View的字段备注的处理,某些知名软件甚至都没有提供).5.能够列出所有的...
3.查看表结构非常方便,同时对表的数据维护调试也非常得顺手; 4.修改TABLE名,VIEW名,COLUMN信息非常方便,最关键的是对它们的备注修改非常方便(对于View的字段备注的处理,某些知名软件甚至都没有提供); 5.能够...
4. **备注信息**:在Oracle表中,可以使用`COMMENT ON COLUMN`语句添加对字段的描述。Excel中的备注信息会被转化为这些注释,提供给数据库管理员和开发人员参考,提高代码可读性。 5. **脚本生成**:工具会根据...
查看表结构非常方便,同时对表的数据维护调试也非常得顺手; 4.修改TABLE名,VIEW名,COLUMN信息非常方便,最关键的是对它们的备注修改非常方便(对于View的字段备注的处理,某些知名软件甚至都没有提供); 5....
- **可视化工具创建**:例如企业管理器,允许用户通过图形界面设计数据表结构,包括定义字段名、数据类型、是否可为空等属性。 - **SQL语句创建**:使用`CREATE TABLE`语句,例如: ```sql CREATE TABLE Stu_...