隨筆 - 100  文章 - 50  trackbacks - 0
          <2014年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(3)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          收藏夾

          我收藏的一些文章!

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          oracle數(shù)據(jù)庫導(dǎo)入導(dǎo)出命令!

          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有個(gè)好處,雖然你的電腦不是服務(wù)器,但是你裝了oracle客戶端,并建立了連接
           (通過Net Configuration Assistant添加正確的服務(wù)命名,其實(shí)你可以想成是客戶端與服務(wù)器端 修了條路,然后數(shù)據(jù)就可以被拉過來了)
           這樣你可以把數(shù)據(jù)導(dǎo)出到本地,雖然可能服務(wù)器離你很遠(yuǎn)。
           你同樣可以把dmp文件從本地導(dǎo)入到遠(yuǎn)處的數(shù)據(jù)庫服務(wù)器中。
           利用這個(gè)功能你可以構(gòu)建倆個(gè)相同的數(shù)據(jù)庫,一個(gè)用來測試,一個(gè)用來正式使用。
           
          執(zhí)行環(huán)境:可以在SQLPLUS.EXE或者DOS(命令行)中執(zhí)行,
           DOS中可以執(zhí)行時(shí)由于 在oracle 8i 中  安裝目錄\$ora10g\BIN被設(shè)置為全局路徑,
           該目錄下有EXP.EXE與IMP.EXE文件被用來執(zhí)行導(dǎo)入導(dǎo)出。
           oracle用java編寫,我想SQLPLUS.EXE、EXP.EXE、IMP.EXE這倆個(gè)文件是被包裝后的類文件。
           SQLPLUS.EXE調(diào)用EXP.EXE、IMP.EXE他們所包裹的類,完成導(dǎo)入導(dǎo)出功能。
           
          下面介紹的是導(dǎo)入導(dǎo)出的實(shí)例,向?qū)雽?dǎo)出看實(shí)例基本上就可以完成,因?yàn)閷?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
             上面可能有點(diǎn)問題,因?yàn)橛械谋硪呀?jīng)存在,然后它就報(bào)錯(cuò),對該表就不進(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ù)庫時(shí)可以連上的。可以用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)出注意事項(xiàng):導(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 2014-07-17 20:51 fly 閱讀(123) 評論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫學(xué)習(xí)
          主站蜘蛛池模板: 丰宁| 中宁县| 利辛县| 澄江县| 黎平县| 大港区| 汶上县| 秦皇岛市| 南平市| 嫩江县| 芜湖县| 双峰县| 聊城市| 洛阳市| 库车县| 凤翔县| 凤山县| 明水县| 綦江县| 平邑县| 泸定县| 五原县| 六安市| 阜城县| 灌南县| 兴安县| 陇西县| 江油市| 石棉县| 白水县| 晴隆县| 秦皇岛市| 上饶市| 大新县| 澄迈县| 德格县| 平果县| 夏津县| 富锦市| 遂川县| 濉溪县|