亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Unix環(huán)境卸載Oracle表結(jié)構(gòu)文本中的腳本

瀏覽:29日期:2023-11-25 18:28:36
由于Oracle的EXP不能轉(zhuǎn)為文本,所以就自己寫(xiě)了Unix環(huán)境下卸載Oracle表結(jié)構(gòu)文本中的腳本代碼。 所涉及系統(tǒng)表 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 功能: 根據(jù)一個(gè)數(shù)據(jù)庫(kù)或表名來(lái)卸載結(jié)構(gòu),并在當(dāng)前目錄中生成對(duì)應(yīng)的數(shù)據(jù)結(jié)構(gòu)文件,包含表結(jié)構(gòu)、主鍵、外鍵、索引等。 語(yǔ)法: dbschema.sh userid/passwd[@connection][table_name]userid/passwd[@oracle_sid]--登錄數(shù)據(jù)庫(kù)的信息tablename --卸載的表名[可選]舉例說(shuō)明: dbschema.sh test/test@testdb 逐個(gè)處理該用戶的表,在當(dāng)前目錄中生成test.sql腳本。 dbschema.sh test/test@testdb TT 處理test用戶的tt表,在當(dāng)前目錄中生成tt.sql腳本。 腳本說(shuō)明: #!/usr/bin/ksh######################################################### 模塊: dbschema.sh## 描述: 根據(jù)一個(gè)數(shù)據(jù)庫(kù)或表名來(lái)獲取相應(yīng)的結(jié)構(gòu)腳本## 參數(shù) 1 = 用戶名/密碼[@實(shí)例名]# 參數(shù) 2 = 表名/視圖名(可選)## 作者 Bing He## 修改記錄# 日期 修改人 修改描述## 10/20/2003 Bing He 開(kāi)始編寫(xiě)###############################################################################################################-- 局部變量定義lv_argc=0 #命令行入?yún)€(gè)數(shù)lv_loginfo='' #命令行中的登錄信息lv_table_name='' #命令行中的表名信息lv_filename='' #輸出的文件名lv_tab_number=0 #需要處理的表的個(gè)數(shù)lv_sep='' #分隔符lv_grid_str='t' #輸出的距行首的空格lv_deal_table='' #當(dāng)前處理的表lv_file_temp1='get_ddl.temp1' #臨時(shí)文件名lv_file_temp2='get_ddl.temp2' #臨時(shí)文件名lv_file_temp3='get_ddl.temp3' #臨時(shí)文件名lv_file_tab_col='get_ddl.col1' #臨時(shí)文件名lv_file_tab_con='get_ddl.con1' #臨時(shí)文件名lv_file_col_con='get_ddl.con2' #臨時(shí)文件名lv_file_tab_ind='get_ddl.ind1' #臨時(shí)文件名lv_file_col_ind='get_ddl.ind2' #臨時(shí)文件名##########################################################################################################-- 檢查用戶名密碼的權(quán)限f_check_userid(){sqlplus ${lv_loginfo} < /dev/nullset echo off;set heading off;desc user_tables;exit!if [ '$?' -ne 0 ]thenecho 'Error:f_check_userid failed.'echo ' Please check the username/passwd=[${lv_loginfo}].'exitfi}##################################################################################################-- 檢查表是否存在f_check_tablename(){sqlplus ${lv_loginfo} < /dev/nullset echo off;set heading off;spool ${lv_file_temp1}select count(*) from user_tables where table_name='${lv_table_name}';spool offexit!if [ '$?' -ne 0 ]thenecho 'Error:f_check_tablename failed.'echo ' Please check the [${lv_table_name}].'exitfilv_number=`cat ${lv_file_temp1}grep -v '^SQL>'grep -v '^$'grep -v 'rows selected`if [ ${lv_number} -eq 0 ]thenecho 'Error:f_check_tablenaem failed.'echo ' Please check the table [${lv_table_name}] in [${lv_loginfo}].'exitfi}##################################################################################################-- 初始化輸出文件f_generate_file(){if [ ${lv_argc} -eq 1 ]thenlv_str=`echo ${lv_loginfo}cut -d'/' -f1 tr '[:upper:]' '[:lower:]'`lv_str_main='StrUCture For User ${lv_str}'elselv_str=`echo ${lv_table_name} tr '[:upper:]' '[:lower:]'`lv_str_main='Structure For Table ${lv_str}'filv_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}##--生成基礎(chǔ)數(shù)據(jù)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 '--** 第四步: 創(chuàng)建表結(jié)構(gòu),主鍵,索引**--' >> ${lv_filename_create_table}echo ${lv_str1} >> ${lv_filename_create_table}lv_str1='---------------------------------------'echo 'n'${lv_str1} >> ${lv_filename_create_foreign}echo '--** 第五步: 創(chuàng)建外鍵 **--' >> ${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/nullset 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 ] ; thenecho 'Usage:f_get_tables failed.'exitfiif [ -f ${lv_file_temp1} ]thenlv_table_name=`cat ${lv_file_temp1} grep -v '^SQL>' tr -d ' ' tr '[:lower:]' '[:upper:]'`echo ${lv_table_name} > 1.outelseecho 'Error:f_get_tables failed.${lv_file_temp1} file not found!'exitfirm -f ${lv_file_temp1}}#################
主站蜘蛛池模板: 日本级毛片免费观看 | 亚洲国产精品婷婷久久 | 中文字幕免费在线观看动作大片 | 国产一区二区三区在线 | 黄色成年| 视频二区 调教中字 知名国产 | 色屁屁www欧美激情在线观看 | 99久久综合国产精品免费 | 欧美视频二区 | 美女被免费网站视频九色 | 婷婷伊人网 | 一级片小视频 | 全部费免一级毛片不收费 | 日韩视频不卡 | 精品在线视频播放 | 一级特黄aa毛片免费观看 | 免费看黄色的网站 | 千百橹最新亚洲地址在线播放 | 久久99爱爱 | 国产亚洲综合色就色 | 黄色一及 | 黄大色黄美女精品大毛片 | 中国美女做爰视频高清 | 精品国产品香蕉在线观看75 | 南京巨根无套操到你窒息 | 天堂素人搭讪系列嫩模在线观看 | 久久精品亚洲综合一品 | 曰韩美女一级视频 | 国产97公开成人免费视频 | 91精品一区国产高清在线 | 国产精品入口免费麻豆 | 三级全黄在线观看www桃花 | 一级欧美毛片成人 | 99精品在线免费 | 三级黄色毛片网站 | 91短视频在线 | 国产精品免费观看 | 日韩在线观 | 精品国产欧美另类一区 | 人善交zzzxxx另类 | 131美女爽爽爽爱做视频 |