exp導出存儲過程
① oracle導出資料庫
oracle導出資料庫用exp語句。
步驟:
一、win鍵+R鍵,輸入cmd,打開命令提示符。
二、然後根據實際情況選擇不同的exp語句。
exp語句詳解:
1. 獲取幫助
exp help=y
2. 導出一個完整資料庫
exp system/manager file=bible_db log=dible_db full=y
3. 導出資料庫定義而不導出數據
exp system/manager file=bible_db log=dible_db full=y rows=n
4. 導出一個或一組指定用戶所屬的全部表、索引和其他對象
exp system/manager file=seapark log=seapark owner=seapark
exp system/manager file=seapark log=seapark owner=(seapark,amy,amyc,harold)
注意:在導出用戶時,盡管已經得到了這個用戶的所有對象,但是還是不能得到這些對象引用的任何同義詞。解決方法是用以下的sql*Plus命令創建一個腳本文件,運行這個腳本文件可以獲得一個重建seapark所屬對象的全部公共同義詞的可執行腳本,然後在目標資料庫上運行該腳本就可重建同義詞了。
SET LINESIZE 132
SET PAGESIZE 0
SET TRIMSPOOL ON
SPOOL c:seapark.syn
SELECT 'Create public synonym '||synonym_name
||' for '||table_owner||'.'||table_name||';'
FROM dba_synonyms
WHERE table_owner = 'SEAPARK' AND owner = 'PUBLIC';
SPOOL OFF
5. 導出一個或多個指定表
exp seapark/seapark file=tank log=tank tables=tank
exp system/manager file=tank log=tank tables=seapark.tank
exp system/manager file=tank log=tank tables=(seapark.tank,amy.artist)
6. 估計導出文件的大小
全部表總位元組數:
SELECT sum(bytes)
FROM dba_segments
WHERE segment_type = 'TABLE';
seapark用戶所屬表的總位元組數:
SELECT sum(bytes)
FROM dba_segments
WHERE owner = 'SEAPARK'
AND segment_type = 'TABLE';
seapark用戶下的aquatic_animal表的位元組數:
SELECT sum(bytes)
FROM dba_segments
WHERE owner = 'SEAPARK'
AND segment_type = 'TABLE'
AND segment_name = 'AQUATIC_ANIMAL';
7. 導出表數據的子集(oracle8i以上)
NT系統:
exp system/manager query='Where salad_type='FRUIT'' tables=amy.salad_type
file=fruit log=fruit
UNIX系統:
exp system/manager query="Where salad_type='FRUIT'" tables=amy.salad_type
file=fruit log=fruit
8. 用多個文件分割一個導出文件
exp system/manager
file=(paycheck_1,paycheck_2,paycheck_3,paycheck_4)
log=paycheck, filesize=1G tables=hr.paycheck
9. 使用參數文件
exp system/manager parfile=bible_tables.par
bible_tables.par參數文件:
#Export the sample tables used for the Oracle8i Database Administrator's Bible.
file=bible_tables
log=bible_tables
tables=(
amy.artist
amy.books
seapark.checkup
seapark.items
)
10. 增量導出
「完全」增量導出(complete),即備份整個資料庫
exp system/manager inctype=complete file=990702.dmp
「增量型」增量導出(incremental),即備份上一次備份後改變的數據
exp system/manager inctype=incremental file=990702.dmp
「累計型」增量導出(cumulative),即備份上一次「完全」導出之後改變的數據
exp system/manager inctype=cumulative file=990702.dmp
② 如何導出ORACLE指定存儲過程
1、要想連接到一個資料庫,先得配置一個tnsnames.ora文件。路徑位於 【XX】/NETWORK/ADMIN/tnsnames.ora。【XX】視具體情況而定。
截圖中紅框標記的地方需要改成你需要連接的資料庫的信息。
注意事項
若出現亂碼,可能需要將編寫的sql文件轉換為utf-8格式。
若提示無法創建spool文件,請確保目錄C:/EXP/DDL存在,或者指定新的路徑。
③ oracle 存儲過程備份整個資料庫
exp username/password@dbname file=d:\db.dmp log=d:\db.log
username和password 是你的用戶名和密碼
dbname是你要備份的資料庫名
file後是你備份的文件存放的路徑 db.dmp是備份獲得的資料庫文件
db.log是日誌文件
如果你要備份的資料庫很大的話還有另一個方法就是使用sqluldr2工具導出資料庫,不過這個稍微麻煩一些,如果還有疑問,再問吧
④ Oracle如何導入存儲過程各位大蝦,幫幫忙!
各位大蝦,幫幫忙! 使用Oracle導入表可以,但應該怎麼導入存儲過程呢? 滿意答案未知元素7級2011-01-17你是使用imp程序導入的,是吧?如果用imp的話,直接導入就可以了! 追問: 我導入了,不過載存儲過程裡面沒有啊! 回答: 你刷新一下看看! 追問: 刷新了,不過就是沒有啊!導入表可以,但是存儲過程就不行了!導出存儲過程的時候是用導出用戶對象導的,但是導入的時候只能用導入表啊,還有其他的方法嗎? 回答: 你可以試著使用exp命令導出,然後imp命令導入! 追問: 哦!我知道了,試一下!謝謝!
⑤ oracle的exp導出的具體使用方法
對於:oracle的exp,就你的問題簡答如下:
1、用戶名和密碼,提供這兩個參數的作用是什麼?
ORACLE是有許可權管理及加密的,不知道用戶名與密碼會讓你導不出數據。
(當然,如果你能本地登錄安裝ORALCE的地伺服器,一般可以用管理員身份強登後改密碼進行相關處理)。
2、提供用戶名是導出該用戶下的所有內容嗎?
ORACLE中,用戶與資料庫是相對獨立的概念,就象某幾個人與某幾個辦公室,並不是一一對應關系,一個人可以有幾個辦公室的鑰匙,當然,也可能一個辦公室的鑰匙都沒有,或是只有能過窗戶查看某個辦公室內情況的權。
所以,某個用戶,可以導出該用戶下的內容,也可以導出其它用戶的內容,前提是你登錄的這個用戶有相關的許可權。
比如sys用戶一般就是超級用戶,可以導出所有用戶的對象(表、存儲過程,等等)。
3、那提供的資料庫名又是干什麼的?
就是上面我說的「辦公室」的概念了。一般exp一次只能導出一個「辦公室」(資料庫)里的數據。
⑥ oracle 11g expdp 可以導出存儲過程嗎
為什麼非要用expdp導出,直接復制就好了。
可以導出存儲過程,我知道imp導入時有一個編譯的參數(COMPILE,默認是Y),那麼exp一定可以導出。
expdp是exp的升級版本,那麼按照用戶導出的,應該也會包含該用戶下的過程。
只導出存儲過程的,似乎不行。
⑦ exp導出資料庫只導出表結構和存儲過程
導出文件:
EXPDAT.DMP
>
e:\test.dmp
(1)E(完整的資料庫),
(2)U(用戶)
或
(3)T(表):
(2)U
>
導出許可權
(yes/no):
yes
>
導出表數據
(yes/no):
yes
>
在導出的界面中,有一項選擇
導出表數據
(yes/no):
yes
,輸入no
即可。