linux指令碼完成重複執行的命令

賀子_DBA時代發表於2015-03-25
要對16個使用者下的同一個表進行操作:
[
oracle@rac1 ~]$ cat a
dic_DE_DE
dic_EN_US
dic_AR_SA
dic_FR_FR
dic_RU_RU
dic_VI_VN
dic_JA_JP
dic_KO_KR
dic_ES_ES
dic_PT_PT
dic_IT_IT
dic_ZH_TW
dic_MS_MY
dic_IN_ID
dic_TH_TH

指令碼:
for i in `cat a` 
do
cat <<eof
impdp    system/"manager(*)0202"    directory=bak  dumpfile= hehe${i}.dmp  tables =${i}.TD_COMMON_CONTENT remap_tablespace=DIC_DATA:DIC_DATA  remap_tablespace=DICTEST:SYSTEM   remap_schema=${i}:${i}       TABLE_EXISTS_ACTION=replace;
eof
done
然後:[oracle@rac1 ~]$ ./b                 就會顯示修改好的語句,直接貼上複製 執行就行。
不用像下面這樣一次一次的去改使用者名稱
impdp    system/"manager(*)0202"    directory=bak  dumpfile=heheDE_DE .dmp  tables =dic_DE_DE.TD_COMMON_CONTENT remap_tablespace=DIC_DATA:DIC_DATA   remap_schema=dic_DE_DE:dic_DE_DE       TABLE_EXISTS_ACTION=replace;

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29654823/viewspace-1473227/,如需轉載,請註明出處,否則將追究法律責任。

相關文章