酒醒無夢

          我在幻象的迷留界徘徊,誰來指引幻象的輪回?

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            8 Posts :: 0 Stories :: 0 Comments :: 0 Trackbacks

          Oracle數(shù)據(jù)導(dǎo)入導(dǎo)出imp/exp
          功能:Oracle數(shù)據(jù)導(dǎo)入導(dǎo)出imp/exp就相當(dāng)與oracle數(shù)據(jù)還原與備份。
           
          大多情況都可以用Oracle數(shù)據(jù)導(dǎo)入導(dǎo)出完成數(shù)據(jù)的備份和還原(不會造成數(shù)據(jù)的丟失)。
           Oracle有個好處,雖然你的電腦不是服務(wù)器,但是你裝了oracle客戶端,并建立了連接
           (通過Net Configuration Assistant添加正確的服務(wù)命名,其實你可以想成是客戶端與服務(wù)器端 修了條路,然后數(shù)據(jù)就可以被拉過來了)
           這樣你可以把數(shù)據(jù)導(dǎo)出到本地,雖然可能服務(wù)器離你很遠(yuǎn)。
           你同樣可以把dmp文件從本地導(dǎo)入到遠(yuǎn)處的數(shù)據(jù)庫服務(wù)器中。
           利用這個功能你可以構(gòu)建倆個相同的數(shù)據(jù)庫,一個用來測試,一個用來正式使用。
           
          執(zhí)行環(huán)境:可以在SQLPLUS.EXE或者DOS(命令行)中執(zhí)行,
           DOS中可以執(zhí)行時由于 在oracle 8i 中  安裝目錄\$ora10g\BIN被設(shè)置為全局路徑,
           該目錄下有EXP.EXE與IMP.EXE文件被用來執(zhí)行導(dǎo)入導(dǎo)出。
           oracle用java編寫,我想SQLPLUS.EXE、EXP.EXE、IMP.EXE這倆個文件是被包裝后的類文件。
           SQLPLUS.EXE調(diào)用EXP.EXE、IMP.EXE他們所包裹的類,完成導(dǎo)入導(dǎo)出功能。
           
          下面介紹的是導(dǎo)入導(dǎo)出的實例,向?qū)雽?dǎo)出看實例基本上就可以完成,因為導(dǎo)入導(dǎo)出很簡單。
          數(shù)據(jù)導(dǎo)出:
           1 將數(shù)據(jù)庫TEST完全導(dǎo)出,用戶名system 密碼manager 導(dǎo)出到D:\daochu.dmp中
             exp system/manager@TEST file=d:\daochu.dmp full=y
           2 將數(shù)據(jù)庫中system用戶與sys用戶的表導(dǎo)出
             exp system/manager@TEST file=d:\daochu.dmp owner=(system,sys)
           3 將數(shù)據(jù)庫中的表table1 、table2導(dǎo)出
             exp system/manager@TEST file=d:\daochu.dmp tables=(table1,table2)
           4 將數(shù)據(jù)庫中的表table1中的字段filed1以"00"打頭的數(shù)據(jù)導(dǎo)出
             exp system/manager@TEST file=d:\daochu.dmp tables=(table1) query=\" where filed1 like  '00%'\"
           
               上面是常用的導(dǎo)出,對于壓縮我不太在意,用winzip把dmp文件可以很好的壓縮。
                               不過在上面命令后面 加上 compress=y  就可以了

          數(shù)據(jù)的導(dǎo)入
           1 將D:\daochu.dmp 中的數(shù)據(jù)導(dǎo)入 TEST數(shù)據(jù)庫中。
             imp system/manager@TEST  file=d:\daochu.dmp
             上面可能有點問題,因為有的表已經(jīng)存在,然后它就報錯,對該表就不進(jìn)行導(dǎo)入。
             在后面加上 ignore=y 就可以了。
           2 將d:\daochu.dmp中的表table1 導(dǎo)入
           imp system/manager@TEST  file=d:\daochu.dmp  tables=(table1)
           
           基本上上面的導(dǎo)入導(dǎo)出夠用了。不少情況我是將表徹底刪除,然后導(dǎo)入。
           
          注意:
           你要有足夠的權(quán)限,權(quán)限不夠它會提示你。
           數(shù)據(jù)庫時可以連上的。可以用tnsping TEST 來獲得數(shù)據(jù)庫TEST能否連上。

           

          數(shù)據(jù)導(dǎo)出:
          exp hkb/hkb@boss_14 full=y file=c:\orabackup\hkbfull.dmp log=c:\orabackup\hkbfull.log;

          導(dǎo)出注意事項:導(dǎo)出的是當(dāng)前用戶的的數(shù)據(jù),當(dāng)前用戶如果有DBA的權(quán)限,則導(dǎo)出所有數(shù)據(jù)!

          同名用戶之間的數(shù)據(jù)導(dǎo)入:
          imp hkb/hkb@xe  file=c:\orabackup\hkbfull.dmp log=c:\orabackup\hkbimp.log full=y

          不同名之間的數(shù)據(jù)導(dǎo)入:
          imp system/test@xe fromuser=hkb touser=hkb_new file=c:\orabackup\hkbfull.dmp

          log=c:\orabackup\hkbimp.log;

          posted on 2010-05-25 19:16 Rock N' Java 閱讀(192) 評論(0)  編輯  收藏 所屬分類: Programming
          主站蜘蛛池模板: 额敏县| 木里| 贵南县| 南江县| 镇康县| 塔城市| 灵石县| 九寨沟县| 祁东县| 乌兰浩特市| 图片| 嘉定区| 阿图什市| 广宁县| 双城市| 上虞市| 扬中市| 浮梁县| 武强县| 阿鲁科尔沁旗| 化德县| 灌南县| 枞阳县| 乳源| 霍城县| 渝中区| 姜堰市| 沙湾县| 枣阳市| 绥化市| 同仁县| 长乐市| 阳曲县| 长垣县| 台东市| 株洲市| 固原市| 英吉沙县| 五寨县| 武川县| 泰宁县|