成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle數據庫遷移相關技巧介紹

數據庫 Oracle 數據庫運維
在Oracle數據庫遷移過程中,會碰到一些平臺和版本的問題。本文將為大家介紹的一些Oracle數據庫遷移相關技巧。

本文將講述的是Oracle數據庫遷移的一些技巧,包括Oracle數據庫遷移前的準備工作,以及不同類型遷移的處理方法。希望對大家了解Oracle數據庫遷移有所幫助。51CTO數據庫頻道之前也曾為大家介紹過《Oracle跨平臺遷移結構而不遷移數據方法詳解》。

去年年底做了不少系統的數據遷移,大部分系統由于平臺和版本的原因,做的是邏輯遷移,少部分做的是物理遷移,有一些心得體會,與大家分享。

首先說說遷移流程,在遷移之前,寫好方案,特別是實施的方案步驟一定要寫清楚,然后進行完整的測試。我們在遷移時,有的系統測試了四五次,通過測試來完善方案和流程。

針對物理遷移,也即通過RMAN備份來進行還原并應用歸檔的方式(這里不討論通過dd方式進行的冷遷移),雖然注意的是要將數據庫設為force logging的方式,在用RMAN做全備之前,一定要執行:

  1. view plaincopy to clipboardprint?  
  2. alter database force logging;   
  3. alter database force logging; 

否則可能會產生壞塊。

對于邏輯遷移,在job_processes設置為>0的數值之前,注意job的下次執行時間和job所屬用戶。比如job的定義在之前已經導入,但是在遷移之時,job已經運行過,那么遷移完成之后,job的下次時間還是原來的時間,這樣可能會重復運行。另外,job通過IMP導入后,job所屬用戶會變成導入用戶的名稱,顯然job原來的用戶就不能對JOB進行管理了,可以通過下面的sql進行修改:

  1. view plaincopy to clipboardprint?  
  2. update sys.job$ set lowner=cowner , powner=cowner;   
  3. update sys.job$ set lowner=cowner , powner=cowner; 

在遷移之前,應該禁止對系統進行結構上的修改和發布,比如表結構,索引,存儲過程包等。

如果是用exp/imp導入的對象,包括存儲過程等,應該檢查對象是否與原生產庫一致,比如由于dblink的原因,imp之后,存儲過程不能創建,導致有部分存儲過程丟失,盡管這些存儲過程可能沒有被使用。

下面是一些加快遷移速度的技巧:

通過dblink,使用append insert的方式,同時利用并行,這種方式比exp/imp更快

對于有LONG類型的列,insert..select的方式顯然是不行的,可以通過exp/imp的方式,但是這種方式速度非常慢,其原因在于imp時一行一行地插入表。有另外一種方式,即sqlplus的copy命令,下面是一個示例: view plaincopy to clipboardprint?

  1. spool copy_long_table_1.log     
  2. conn / as sysdba     
  3. set copycommit=2000     
  4. set arraysize 30     
  5. set long 10485760     
  6.     
  7. copy from system/xxxx@source_db append username.table_name using select * from username.table_name;     
  8.     
  9. spool off    
  10. exit   
  11.  
  12. spool copy_long_table_1.log  
  13. conn / as sysdba  
  14. set copycommit=2000  
  15. set arraysize 30  
  16. set long 10485760  
  17.  
  18. copy from system/xxxx@source_db append username.table_name using select * from username.table_name;  
  19.  
  20. spool off 
  21. exit 

不過,sqlpus的copy命令不支持有timestamp和lob列類型的表。如果有timestamp類型的表,可以通過在exp時,加上rowid的條件,將一個表分成多個部分同時操作,對于有lob類型的表,也可以同樣處理(因為insert …select方式下,有lob類型列時,也同樣是一行一行地插入)。注意在這種方式下,就不能使用direct的方式exp/imp。下面是exp導出時parfile示例:

  1. query="where rowid>=dbms_rowid.rowid_create(1,71224,52,9,0) and rowid<=dbms_rowid.rowid_create(1,71224,55,1038344,10000)"    
  2. file=/dumpdata/n1.dmp     
  3. tables=username.table1     
  4. constraints=n     
  5. grants=no    
  6. indexes=no    
  7. buffer=104857600     
  8. ...     
  9. ...     
  10. query="where rowid>=dbms_rowid.rowid_create(1,71224,423,137,0) and rowid<=dbms_rowid.rowid_create(1,71224,432,59272,10000)"    
  11. file=/dumpdata/n6.dmp     
  12. tables=username.table1     
  13. constraints=n     
  14. grants=no    
  15. indexes=no    
  16. buffer=104857600   
  17.  
  18. query="where rowid>=dbms_rowid.rowid_create(1,71224,52,9,0) and rowid<=dbms_rowid.rowid_create(1,71224,55,1038344,10000)" 
  19. file=/dumpdata/n1.dmp  
  20. tables=username.table1  
  21. constraints=n  
  22. grants=no 
  23. indexes=no 
  24. buffer=104857600  
  25. ...  
  26. ...  
  27. query="where rowid>=dbms_rowid.rowid_create(1,71224,423,137,0) and rowid<=dbms_rowid.rowid_create(1,71224,432,59272,10000)" 
  28. file=/dumpdata/n6.dmp  
  29. tables=username.table1  
  30. constraints=n  
  31. grants=no 
  32. indexes=no 
  33. buffer=104857600 

將表分成幾部分同時操作,不僅僅可以利用rowid,也可以利用表上的列,比如說,表上有一個created_date的列,并且保證是遞增插入數據,那么這種情況下,也可以使用這個字段將表分成不同的范圍同時進行導出和導入。不過使用ROWID通常具有更高的效率。

當然對于有lob列的表,可以按上述方式,拆成多個insert方式同時插入,不需要exp/imp。

對于特別大的分區表,雖然使用并行可以提高速度,但是受限于單個進程(不能跨DB LINK進行并行事務,只能并行查詢,也即insert..select只能是SELECT部分才能進行并行)的處理能力,這種方式下速度仍然有限。可以并行將數據插入多個中間表,然后通過exchange partition without validation 的方式,交換分區,這種方式將會大大提高了速度。

有朋友可能會問,為什么不并行直接插入分區表,當然如果是非direct path(append)方式,則是沒問題的,但是這種方式插入的性能較低。而direct path的方式,會在表上持有mode=6(互斥)的TM鎖,不能多個會話同時插入。(update: 在insert 時使用這樣的語句:insert into tablename partition (partname) select * from tablename where ….,更簡單更有效率。)

遷移時,將數據分成兩部分,一部分是歷史表,第二部分是動態變化的表,在遷移之前,先導入歷史表,并在歷史表上建好索引,這無疑會大大減少遷移時業務系統中斷時間。
遷移之前,考慮清理掉垃圾數據。

遷移時,應保證表上沒有任何索引,約束(NOT NULL除外)和觸發器,數據導入完成后,再建索引。建索引時同樣,同時使用多個進程跑腳本。索引創建無成后,應去掉索引的PARALLEL屬性。

在創建約束時,應按先創建CHECK約束,主鍵,***鍵,再創建外鍵約束的順序。約束狀態為 ENABLE NOVALIDATE,這將大大減少約束創建時間。而在遷移完成后,再考慮設回為ENABLE VALIDATE。

通過使用dbms_stats.export_schame_stats和dbms_stats.import_schame_stats導入原庫上的統計信息,而不用重新收集統計使用。
朋友們可以看到,以上均是針對9i的,實際上在10g甚至11g環境下,也仍然很多借鑒意義。當然這些技巧不僅僅用于完整的數據庫遷移,也可以應用到將個別表復制到其他數據庫上。

這里沒有提到的是利用物化視圖或高級復制、觸發器之類的技術,因為這些技術,畢竟要修改生產庫,對生產庫的運行有比較大的影響,因此,只有在停機時間要求特別嚴格,而在這個時間內又不能完成遷移時才應該考慮。

從遷移的經驗來說,只有完善的流程,完整的測試才可以保證成功。這里只是列舉了一些小技巧,如果對整個遷移過程有興趣,可以針對這個話題再進行討論。

原文鏈接:http://www.laoxiong.net/some_data_migration_tips.html

【編輯推薦】

  1. 淺談存取Oracle當中掃描數據的方法
  2. Oracle設置系統參數進行性能優化
  3. Oracle數據庫維護中的前瞻性
  4. Oracle與SQL Server之間的數據遷移
  5. 實例講解Oracle到SQL Server主鍵遷移
責任編輯:彭凡 來源: laoxiong.net
相關推薦

2010-04-07 09:31:02

Oracle數據庫

2011-09-02 10:37:15

Oraclesqlload用法

2010-01-07 17:24:12

VB.NET連接數據庫

2010-04-21 14:45:39

Oracle數據庫

2010-04-20 12:09:31

Oracle數據庫

2015-10-28 17:39:04

ORACLE AIO異步IO

2015-10-28 14:45:35

ORACLE AIO異步IO

2010-04-06 11:19:28

Oracle數據庫

2011-09-02 10:06:51

OracleSqlLoad常用技巧

2010-04-23 12:24:06

Oracle數據庫

2010-04-23 09:32:39

Oracle數據庫實例

2017-04-07 15:00:57

Lotus-NotesORACLE數據遷移

2009-12-29 11:15:45

ADO數據庫

2009-08-24 18:09:13

C#調用Oracle數

2010-04-15 13:01:25

Oracel數據庫

2019-10-16 11:40:56

數據庫PostgreSQL Oracle

2009-08-07 18:07:58

C#數據庫開發

2011-05-17 13:43:23

Oracle數據庫

2011-03-17 16:19:42

Oracle數據庫管理

2009-05-18 13:18:54

字符Oracle字符串
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久在草| 亚洲精品视频在线播放 | 久久久久久黄 | 国产 亚洲 网红 主播 | 国产精品毛片一区二区三区 | 国产精品美女久久久 | 一级毛片在线视频 | 欧美αv | 日韩一区二区三区视频 | 五月激情综合 | 色婷婷综合久久久久中文一区二区 | 日韩电影中文字幕 | 91精品国产91久久久久久 | 亚洲成人综合在线 | 久久精品青青大伊人av | 国产精品一区视频 | 日本在线免费观看 | 久久久久久久久久影视 | 羞羞网站在线观看 | 国产精品区二区三区日本 | 精品国产一区二区三区久久久四川 | 97精品视频在线观看 | 欧美亚洲日本 | 欧美日韩亚洲系列 | 国产成人精品视频在线观看 | www在线视频 | 99久久精品免费看国产四区 | 亚洲精品三级 | 91黄色免费看 | 日韩av美女电影 | 最新日韩av| 国产精品免费一区二区三区四区 | 午夜免费观看网站 | 久久久久久高潮国产精品视 | 草在线| 亚洲福利一区 | 青娱乐国产 | 精品日韩一区二区 | 午夜av免费| 国产精品国产三级国产aⅴ中文 | 久久久精品一区二区三区四季av |