oracle-脚本-导出某属主用户的所有表结构(excel格式)

#!/bin/bash
# Desc: 用于导出某属主用户的所有表结构: 表明、字段名、字段类型

## declare variables
sid_profile="/home/oracle/xxxprofile"
table_owner="xxx"
table_list_file="${table_owner}_tables.list"
get_table_structures_sql="get_${table_owner}_table_structures.sql"
table_structures_file="${table_owner}_table_structures.xls"
base_dir="/home/oracle/dw_standbys"

## env init
. ${sid_profile}
cd ${base_dir}

## get table list
sqlplus -S / as sysdba < set linesize 200
set trimspool on feedback off pagesize 0
spool ${table_list_file}
select table_name from dba_tables where owner=upper('${table_owner}') order by 1;
spool off
EOF
sed -i '/^SQL>/d;/^$/d' ${table_list_file}

## generate sql script for getting table structures
cat /dev/null >${get_table_structures_sql}
# format sqlplus output as .xls file
echo -e "set term off verify off feedback off pagesize 999 \nset markup html on entmap ON spool on preformat off">> ${get_table_structures_sql}
#
echo -e "alter session set current_schema=\"${table_owner}\";" >>${get_table_structures_sql}
echo -e "spool ${table_structures_file}" >>${get_table_structures_sql}
echo -e "col Count_Tables for 999999999\ncol GaterDate for a30\n col TableOwner for a20">>${get_table_structures_sql}
echo -e "select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') GatherDate,'${table_owner}' TableOwner,(select count(1) from dba_tables where owner='${table_owner}') Count_Tables  from dual;">>${get_table_structures_sql}
echo -e "col comment for a30" >>${get_table_structures_sql}
for table_name in `cat ${table_list_file}`
do
  echo "select table_name,column_name,data_type,' ' as \"comment\" from DBA_TAB_COLS where owner=upper('${table_owner}') and table_name=upper('${table_name}');">>${get_table_structures_sql}
done
echo -e "spool off" >>${get_table_structures_sql}

## get table structures
sqlplus -S / as sysdba < @${get_table_structures_sql}
EOF
result_status="$?"
if [ ${result_status} -eq 0 ];then
  echo "Info: the table structure file of ${table_owner} is ${table_structures_file}."
else
  echo "Critical: something is wrong with ${table_structures_file} !"
fi

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/25856403/viewspace-1074709/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/25856403/viewspace-1074709/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
适用的数据库: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、付费专栏及课程。

余额充值