导出 Oracle 数据库中所所有用户表的表结构

问题描述:

         将 Oracle 数据库中所有用户表的表结构导出,并存储到 Excel 表中,存储信息如下图所示:

SELECT A.TABLE_NAME,A.COMMENTS,B.COLUMN_NAME,B.COMMENTS  FROM USER_TAB_COMMENTS a,USER_COL_COMMENTS b WHERE a.table_name = b.table_name

解决方案:

1)  启动 PL/SQL ,应用需要导出表结构的用户登录目标数据库实例

2)  New-SQL window 创建查询窗口

3)  在查询窗口中输入以下查询语句:

select t.TABLE_NAME 表名 ,t.COLUMN_ID 序号 ,t.COLUMN_NAME 字段名 ,t.DATA_TYPE 类型 ,t. DATA_LENGTH 长度 ,t.NULLABLE 是否为空

from user_tab_columns t

其中 User_tab_columns 为当前用户表结构信息表。

4)  只想完成后,在查询窗口中点击按钮显示所有记录信息

5)  右键 -copy to Excel ,将查询信息保存到 Excel 中

6)  通过 Excel 中打开保存的查询结果数据,选择数据 - 筛选,选择不同的表,然后可以取出不同表的表结构

7)  如果在查询过程中选择特定表的表结构则执行以下语句

select t.TABLE_NAME 表名 ,t.COLUMN_ID 序号 ,t.COLUMN_NAME 字段名 ,t.DATA_TYPE 类型 ,t. DATA_LENGTH 长度 ,t.NULLABLE 是否为空

from user_tab_columns t

where TABLE_NAME=’ 表名 ’

注:这里的表名,需要查询的表名替换,比如 User 表则写成: where TABLE_NAME=’User’

经验总结:

1) 数据表 User_tab_columns 中存储了当前用户所有数据表的表结构。

2) 数据表 all_tab_columns 中存储了当前数据库实例中所有数据表的表结构。

3) 数据表 all_tab_columns 和数据表 user_tab_columns 的区别在于表 all_tab_columns 多了一个 owner 字段,用来存储表所属的用户。

通过 PL/SQL 可以将查询结果直接导出到 Excel 文件中。

 

 

适用的数据库:8i, 9i数据库下该脚本通用<br/><br/>功能:导出一个用户的数据结构,包括、视图、索引、约束、存储过程、触发器、函数、序列等等的定义,并且每个定义为一个文件<br/> 导出的各个对象的定义格式比较规范。<br/> 如的定义为:<br/> prompt Create Table BBNACTIVEHISTORY<br/> CREATE TABLE test(<br/> USERID VARCHAR2(20) NOT NULL,<br/> SPUSERID VARCHAR2(30) NOT NULL,<br/> PRODUCTID VARCHAR2(20) NOT NULL,<br/> GAMETYPE NUMBER NOT NULL,<br/> STARTTIME DATE NOT NULL,<br/> CHARGED CHAR(1) default 'N' NOT NULL<br/> );<br/> <br/> 每个存储过程有多个参数,可以控制输出何种形式的内容,如可以只生成删除的sql,可以在生成的创建与索引的语句上加上storage子句等等。<br/><br/>运行 user_dll_sql.sql的准备工作:<br/><br/>1. 修改win_mkdir.bat文件,以便生成存放生成脚本的基本目录及其子目录<br/> win_mkdir.bat文件生成上面所需要的所有目录<br/> 打开win_mkdir.bat文件,修改BASE_DIC变量的值,如c:\temp\,该目录是存放生成的脚本文件的基本目录<br/> <br/> <br/>2. 运行 win_mkdir.bat文件创建必要的目录<br/><br/>3. 用sql*plus以想导出数据结构用户登陆到数据库<br/> 运行user_dll_sql.sql 生成文件的路径文件,生成所有的ddl语句<br/> 运行文件时,将存放生成脚本的基本目录作为参数(与步骤1改的基本目录一样)传入, ?要根据需要改为实际的目录<br/> SQL> @?\user_ddl_sql.sql c:\temp\<br/> <br/><br/>说明:<br/> 运行win_mkdir.bat,文件后,会自动在生成脚本的基本目录下产生如下目录:<br/> procedures, functions, triggers, packages, temp_sql.<br/> 每个目录的作用如下:<br/> procedures: 该目录存放存储过程, 有子目录separ_files, 该目录下的每个文件都是一个存储过程的源代码 <br/> functions: 该目录存放函数, 有子目录separ_files, 该目录下的每个文件都是一个函数的源代码<br/> triggers: 该目录存放触发器, 有子目录separ_files, 该目录下的每个文件都是一个触发器的源代码<br/> packages: 该目录存放包, 有子目录separ_files, 该目录下的每个文件都是一个包的源代码<br/> 有子目录separ_headbobdy_file, 该目录下的每个文件都是一个包的包头或包体的源代码<br/> temp_sql:存放生成的临时文件<br/>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值