文章分类 | 推荐文章 | 最新文章 | 热点文章 | 最新软件 | 精品软件 | 下载排行 | 推荐下载 | 免费看大片 | WPS | 杀毒软件
清风网络
首 页 软件下载 网络学院 数码学院
QQ 电脑入门 游戏 操作系统 图形处理 办公软件 媒体动画 精文荟萃 工具软件 网络编程 程序开发 网络技术 认证考试 网站建设 文章专栏
当前位置:清风网络学院程序开发OracleUnix环境卸载Oracle表结构文本中的脚本
精品推荐
特别推荐
·常用数据库比较
·ODBC API常用函数诠释
·提高ORACLE数据库的查询统计速度
·细化解析:Oracle使用的hints调整机制
·解析Oracle/Oracle Forms 的多用途代码
·从Oracle的FORM中调用REPORT的实用技巧
·Oracle SQL精妙SQL语句讲解
·ORACLE学习笔记--性能优化四
·ORACLE常用傻瓜问题1000问
·ORACLE常见错误代码的分析与解决之二
热点TOP10
·常用数据库比较
·性能分析工具的使用
·Oracle数据库重做日志文件丢失后的恢复
·细化解析:Oracle使用的hints调整机制
·监控Oracle数据库的常用shell脚本
·ORA-01092: ORACLE 例程终止。强行断开连接
·oracle数据库 exp/imp命令详解
·解析Oracle/Oracle Forms 的多用途代码
·Oracle数据库不同版本间用exp来导数据
·细化解析:Oracle数据库后台进程的功能

Unix环境卸载Oracle表结构文本中的脚本

日期:2008年4月13日 作者: 查看:[大字体 中字体 小字体]


由于Oracle的EXP不能转为文本,所以就自己写了Unix环境下卸载Oracle表结构文本中的脚本代码。

所涉及系统表

1. User_tables 用户表。

2. User_tab_columns 用户表的字段。

3. User_view 用户视图。

4. User_indexes 用户表的索引。

5. User_ind_columns 用户表字段的索引。

6. User_constraints 用户表的限定。

7. User_cons_columns 用户表字段的限定。

使用方法

dbschema.sh

功能:

根据一个数据库或表名来卸载结构,并在当前目录中生成对应的数据结构文件,包含表结构、主键、外键、索引等。

语法:

dbschema.sh userid/passwd[@connection][table_name]
userid/passwd[@oracle_sid]--登录数据库的信息
tablename --卸载的表名[可选]

举例说明:

dbschema.sh test/test@testdb

逐个处理该用户的表,在当前目录中生成test.sql脚本。

dbschema.sh test/test@testdb TT

处理test用户的tt表,在当前目录中生成tt.sql脚本。

脚本说明:

#!/usr/bin/ksh
#######################################################
#
# 模块: dbschema.sh
#
# 描述: 根据一个数据库或表名来获取相应的结构脚本
#
# 参数 1 = 用户名/密码[@实例名]
# 参数 2 = 表名/视图名(可选)
#
# 作者 Bing He
#
# 修改记录
# 日期 修改人 修改描述
#
# 10/20/2003 Bing He 开始编写
#
######################################################

######################################################
##-- 局部变量定义
lv_argc=0 #命令行入参个数
lv_loginfo="" #命令行中的登录信息
lv_table_name="" #命令行中的表名信息
lv_filename="" #输出的文件名
lv_tab_number=0 #需要处理的表的个数
lv_sep='' #分隔符
lv_grid_str="\t" #输出的距行首的空格
lv_deal_table="" #当前处理的表
lv_file_temp1="get_ddl.temp1" #临时文件名
lv_file_temp2="get_ddl.temp2" #临时文件名
lv_file_temp3="get_ddl.temp3" #临时文件名
lv_file_tab_col="get_ddl.col1" #临时文件名
lv_file_tab_con="get_ddl.con1" #临时文件名
lv_file_col_con="get_ddl.con2" #临时文件名
lv_file_tab_ind="get_ddl.ind1" #临时文件名
lv_file_col_ind="get_ddl.ind2" #临时文件名
####################################################

####################################################
##-- 检查用户名密码的权限
f_check_userid()
{
sqlplus ${lv_loginfo} < /dev/null
set echo off;
set heading off;
desc user_tables;
exit
!
if [ "$?" -ne 0 ]
then
echo "Error:f_check_userid failed."
echo " Please check the username/passwd=[${lv_loginfo}]."
exit
fi
}
################################################

################################################
##-- 检查表是否存在
f_check_tablename()
{
sqlplus ${lv_loginfo} < /dev/null
set echo off;
set heading off;
spool ${lv_file_temp1}
select count(*) from user_tables 
where table_name='${lv_table_name}';
spool off
exit
!
if [ "$?" -ne 0 ]
then
echo "Error:f_check_tablename failed."
echo " Please check the [${lv_table_name}]."
exit
fi
lv_number=`cat ${lv_file_temp1}grep -v "^SQL>"
grep -v "^$"grep -v "rows selected`
if [ ${lv_number} -eq 0 ]
then
echo "Error:f_check_tablenaem failed."
echo " Please check the table [${lv_table_name}] 
in [${lv_loginfo}]."
exit
fi
}
################################################

################################################
##-- 初始化输出文件
f_generate_file()
{
if [ ${lv_argc} -eq 1 ]
then
lv_str=`echo ${lv_loginfo}cut -d"/" -f1 
tr "[:upper:]" "[:lower:]"`
lv_str_main="Structure For User ${lv_str}"
else
lv_str=`echo ${lv_table_name} 
tr "[:upper:]" "[:lower:]"`
lv_str_main="Structure For Table ${lv_str}"
fi
lv_filename_drop_index="${lv_str}.drop_index"
lv_filename_drop_foreign="${lv_str}.drop_foreign"
lv_filename_drop_table="${lv_str}.drop_table"
lv_filename_create_table="${lv_str}.create_table"
lv_filename_create_foreign="${lv_str}.create_foreign"
lv_filename="${lv_str}.sql"
rm -f ${lv_filename_drop_index}
rm -f ${lv_filename_drop_foreign}
rm -f ${lv_filename_drop_table}
rm -f ${lv_filename_create_table}
rm -f ${lv_filename_create_foreign}
rm -f ${lv_filename}

##--生成基础数据
lv_str1="-------------------------------------"
echo "\n"${lv_str1} >> ${lv_filename_drop_index}
echo "--** 第一步: 删除索引 **--" >> ${lv_filename_drop_index}
echo ${lv_str1}"\n" >> ${lv_filename_drop_index}

lv_str1="--------------------------------------"
echo "\n"${lv_str1} >> ${lv_filename_drop_foreign}
echo "--** 第二步: 删除外键 **--" >> ${lv_filename_drop_foreign}
echo ${lv_str1}"\n" >> ${lv_filename_drop_foreign}

lv_str1="---------------------------------------"
echo "\n"${lv_str1} >> ${lv_filename_drop_table}
echo "--** 第三步: 删除表 **--" >> ${lv_filename_drop_table}
echo ${lv_str1}"\n" >> ${lv_filename_drop_table}

lv_str1="---------------------------------------"
echo "\n"${lv_str1} >> ${lv_filename_create_table}
echo "--** 第四步: 创建表结构,主键,索引**--" >> ${lv_filename_create_table}
echo ${lv_str1} >> ${lv_filename_create_table}

lv_str1="---------------------------------------"
echo "\n"${lv_str1} >> ${lv_filename_create_foreign}
echo "--** 第五步: 创建外键 **--" >> ${lv_filename_create_foreign}
echo ${lv_str1}"\n" >> ${lv_filename_create_foreign}

lv_str1="---------------------------------------"
echo "\n"${lv_str1} >> ${lv_filename}
echo "--** DESC :${lv_str_main}" >> ${lv_filename}
echo "--** AUTHOR:Bing He" >> ${lv_filename}
echo "--** DATE :20`date +%y-%m-%d" >> ${lv_filename}
echo ${lv_str1}"\n" >> ${lv_filename}

}
#########################################

#########################################
##-- 获取用户下的表列表
f_get_tables()
{
rm -f ${lv_file_temp1}
sqlplus ${lv_loginfo} </dev/null
set colsep ${lv_sep};
set echo off;
set feedback off;
set heading off;
set pagesize 0;
set linesize 1000;
set numwidth 12;
set termout off;
set trimout on;
set trimspool on;
spool ${lv_file_temp1};
select table_name from user_tables;
spool off;
exit
!
if [ "$?" -ne 0 ] ; then
echo "Usage:f_get_tables failed."
exit
fi

if [ -f ${lv_file_temp1} ]
then
lv_table_name=`cat ${lv_file_temp1} grep -v "^SQL>" 
 tr -d ' ' tr "[:lower:]" "[:upper:]"`
echo ${lv_table_name} > 1.out
else
echo "Error:f_get_tables failed.${lv_file_temp1} file not found!"
exit
fi
rm -f ${lv_file_temp1}
}
#################

(出处:清风网络学院






上一篇:如何把应用程序和Oracle客户端一起打包

下一篇:教你如何缩小SQL Server数据库日志文件

相关文章:
·杀毒技巧系列:杀毒、防恶意代码、脚本病毒的不完全合集
·如何卸载netware客户服务
·卸载并不难!轻松卸载程序六技巧
·卸载软件完全手册 将清除进行到底
·如何卸载WindowsXP操作系统
·乳房生理结构(图)
·Oracle数据库重做日志文件丢失后的恢复
·JS经典源码:通用javascript脚本函数库
·Flash AS教程之四 动态文本的编写以及外部文本的载入
·我的声卡驱动程序被我卸载了怎么办!
相关软件:
·完美卸载 2007V26.24 Build 1115 完整版
·Windows环境下32位汇编语言程序设计
·Effective Oracle by design(脚本)
·注册表结构
·常见多音多义字100个文本
·2005年一级注册结构工程师考试钢结构辅导课件
·Oracle认证考试百宝箱V 2.0
·走遍美国 视频+文本 学习英语的绝好资料
·Oracle9i Performance Tuning
·listen to this英语初、中、高级听力(文本)

特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
[打印本页] [关闭窗口] 转载请注明来源:http://www.vipcn.com
| 帮助(?) | 版权声明 | 友情连接 | 关于我们 | 信息发布
Copyright 2007 www.vipcn.com All Rights Reserved. 鄂ICP备05000083号Powered by:vipcn