日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Unix環境卸載Oracle表結構文本中的腳本

瀏覽:83日期:2023-11-25 18:28:36
由于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/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}##--生成基礎數據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/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}}#################
標簽: Oracle 數據庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
综合激情网站| 日韩av一级片| 91精品精品| 亚洲精品1区2区| 日本成人在线不卡视频| 老司机免费视频一区二区三区| 国产一区二区三区日韩精品| 99久久激情| 日韩一区二区三区精品视频第3页 日韩一区二区三区免费视频 | 精品视频一区二区三区在线观看| 国产精选在线| 国产一级久久| 日韩高清一区在线| 精品视频一二| 午夜欧美理论片| 91午夜精品| 肉色欧美久久久久久久免费看| 视频在线观看一区| 精品国产亚洲一区二区三区在线| 欧美日韩四区| 欧美精品中文| 日韩久久精品网| 红桃视频亚洲| 青青伊人久久| 欧美日中文字幕| 欧美亚洲福利| 欧美成人国产| 国产精品a久久久久| 亚洲一级二级| 国产情侣一区| 99在线精品视频在线观看 | 欧美精品影院| 久久香蕉国产| 欧美日韩亚洲一区二区三区在线 | 国产欧美日韩精品一区二区三区| 99久久亚洲精品| 7777精品| 国产精品7m凸凹视频分类| 国产一卡不卡| 91成人精品视频| 国产精品男女| 蜜臀va亚洲va欧美va天堂| 国产aⅴ精品一区二区四区| 视频在线观看91| 91亚洲一区| 欧美一级二区| 亚洲欧美久久久| 免费看av不卡| 91九色综合| 好看的亚洲午夜视频在线| 久久av超碰| 亚洲2区在线| 91精品高清| 国产一区日韩| 欧美在线看片| 老司机久久99久久精品播放免费| 国产在线看片免费视频在线观看| 欧美日韩视频免费看| 性一交一乱一区二区洋洋av| 日韩欧美少妇| 久久精品伊人| 久久激情五月婷婷| 日韩中文字幕av电影| 日韩伦理在线一区| 国产欧美激情| 亚欧成人精品| 9国产精品视频| 91精品国产91久久久久久黑人| 精品亚洲成人| 国产伦乱精品| 日韩一区二区三区精品| 国产高清一区二区| 国产中文在线播放| 久久不见久久见中文字幕免费| 午夜电影一区| 视频在线观看一区| 欧美日韩四区| 激情综合自拍| 日韩综合精品| 国产盗摄——sm在线视频| 国产精品1区在线| 国产精品欧美日韩一区| 91成人在线精品视频| 亚洲丝袜啪啪| 亚洲免费中文| 亚洲一区免费| 亚洲深夜福利| 国产精品日韩久久久| 五月天激情综合网| 1000部精品久久久久久久久| 亚洲精品一级二级| 日韩精品免费一区二区在线观看 | 中国字幕a在线看韩国电影| 久久久精品国产**网站| 国产精品久久久久av蜜臀 | 日韩午夜黄色| 欧美日韩国产一区精品一区| 国产高清一区| 亚洲香蕉网站| 欧美日韩国产综合网| 五月天久久久| 国产一区久久| 欧美日韩国产在线一区| 伊人精品一区| 91精品xxx在线观看| 亚洲欧洲美洲av| 亚洲成av在线| 久久中文字幕av一区二区不卡| 欧美亚洲在线日韩| 免费黄色成人| 亚洲一区二区三区高清不卡| 国产精品嫩草99av在线| 免费视频久久| 亚洲精品伊人| 国产日本亚洲| 九九九精品视频| 久久久久久一区二区| 另类中文字幕国产精品| 国内亚洲精品| 亚州av乱码久久精品蜜桃| 欧美特黄视频| 亚洲精品极品| 国产亚洲欧美日韩精品一区二区三区 | 亚洲视频国产| 欧美日韩精品一区二区三区视频 | 在线精品视频在线观看高清| 午夜亚洲福利在线老司机| 日韩中文av| 鲁大师精品99久久久| 亚洲a在线视频| 免费人成精品欧美精品| 日韩区欧美区| 久久精品网址| 国产在线不卡| 亚洲日产av中文字幕| 久久国内精品| 欧美www视频在线观看| 99久久久国产精品美女| 99国产精品视频免费观看一公开 | 久久精品国产大片免费观看| 日韩中文字幕不卡| 久久99久久人婷婷精品综合| 成人午夜国产| 亚洲乱亚洲高清| 久久久久伊人| 久久精品在线| 日韩有吗在线观看| 国产精品毛片一区二区在线看| 国产中文一区| 欧美自拍一区| 久久久人人人| 日本不卡视频一二三区| 日韩av有码| 蜜臀av国产精品久久久久| 免费日韩成人| 免费av一区二区三区四区| 日韩福利视频一区| 日韩国产欧美| 日本成人中文字幕| 久久久久网站| 日韩1区2区日韩1区2区| a日韩av网址| 日韩午夜视频在线| 91综合视频| 亚洲a成人v| 久久精品国产www456c0m| 日韩精品一页| 久久久噜噜噜| 国产精品红桃| 蜜臀av性久久久久蜜臀aⅴ四虎| 成人在线免费观看网站| 老司机精品久久| 日韩av片子| 日本中文字幕一区二区| 日韩精品免费一区二区在线观看 | 国产乱码精品一区二区三区亚洲人| 丝袜美腿诱惑一区二区三区 | 国产丝袜一区| 视频一区二区三区入口| 国产精品va| 欧美jjzz| 国产精品亚洲一区二区在线观看| 久久中文字幕二区| 日韩高清电影免费| 日韩欧美国产精品综合嫩v| 日本欧美在线看| 成人在线超碰| 亚洲毛片在线免费| 色网在线免费观看| 亚洲三级网站| 精品一区二区三区中文字幕在线| 亚洲精品在线观看91| 欧美aⅴ一区二区三区视频| 亚洲黄页一区| 国产一区二区三区亚洲| 久久成人亚洲| 色偷偷色偷偷色偷偷在线视频| 亚洲v天堂v手机在线| 日韩三区免费| 国产欧美精品久久|