Oracle12c_PDB的拔插與刪除
這裡簡單介紹了拔出PDB,刪除PDB,插入PDB的操作方法:
1、unplug PDB
檢視PDB資訊:
SQL> select name,open_mode from v$pdbs;
NAME OPEN_MODE
------------------------------ ----------
PDB$SEED READ ONLY
PDB_1 READ WRITE
PDB_2 READ WRITE
PDB_3 READ WRITE
PDB_4 READ WRITE
SQL> show con_name;
CON_NAME
------------------------------
CDB$ROOT
拔出PDB_4(必須連線到CDB$ROOT):
首先關閉PDB_4
SQL> alter pluggable database pdb_4 close immediate;
Pluggable database altered.
然後就可以unplug
SQL> alter pluggable database pdb_4 unplug into '/home/oracle/unplugged_pdbs/pdb_4.xml';
Pluggable database altered.
XML檔案中包含了每個資料檔案的位置,以及初始化引數等資訊。
2、drop PDB
關閉並且拔出PDB後才可以進行刪除,刪除時可以一起刪除資料檔案:
同樣需要連線到CDB$ROOT容器,執行下列語句:
SQL> drop pluggable database pdb_4 keep datafiles;
Pluggable database dropped.
SQL> select name,open_mode from v$pdbs;
NAME OPEN_MODE
------------------------------ ----------
PDB$SEED READ ONLY
PDB_1 READ WRITE
PDB_2 READ WRITE
PDB_3 READ WRITE
這裡使用了keep datafiles保留了PDB_4的資料檔案。另外,也可以使用inluding datafiles徹底刪除PDB的資料檔案。
3、plug an unplugged PDB
plug PDB_4:
SQL> create pluggable database pdb_4_replug using '/home/oracle/unplugged_pdbs/pdb_4.xml' nocopy tempfile reuse;
Pluggable database created.
SQL> select name from v$pdbs;
NAME
------------------------------
PDB$SEED
PDB_1
PDB_2
PDB_3
PDB_4_REPLUG
SQL> select name,open_mode from v$pdbs;
NAME OPEN_MODE
------------------------------ ----------
PDB$SEED READ ONLY
PDB_1 READ WRITE
PDB_2 READ WRITE
PDB_3 READ WRITE
PDB_4_REPLUG MOUNTED
上述create pluggable database語句中,因為資料檔案都在xml檔案指定的位置,且仍使用原來的位置作為新
的pdb的資料檔案的儲存位置,因此沒有包含其他子句。
另外一條plug PDB的語句也可能如下:
CREATE PLUGGABLE DATABASE pdbname
USING '/location/filename.xml'
SOURCE_FILE_NAME_CONVERT=('/location1/','/location2/')
MOVE
FILE_NAME_CONVERT=('/location2/','/location3/')
PATH_PREFIX='/location3/'
STORAGE (MAXSIZE 2G MAX_SHARED_TEMP_SIZE 100M);
這裡xml檔案中指示資料檔案在/location1/中,而實際上資料檔案在/location2/中,且最終我們要將資料檔案
放在/location3/中
1、unplug PDB
檢視PDB資訊:
SQL> select name,open_mode from v$pdbs;
NAME OPEN_MODE
------------------------------ ----------
PDB$SEED READ ONLY
PDB_1 READ WRITE
PDB_2 READ WRITE
PDB_3 READ WRITE
PDB_4 READ WRITE
SQL> show con_name;
CON_NAME
------------------------------
CDB$ROOT
拔出PDB_4(必須連線到CDB$ROOT):
首先關閉PDB_4
SQL> alter pluggable database pdb_4 close immediate;
Pluggable database altered.
然後就可以unplug
SQL> alter pluggable database pdb_4 unplug into '/home/oracle/unplugged_pdbs/pdb_4.xml';
Pluggable database altered.
XML檔案中包含了每個資料檔案的位置,以及初始化引數等資訊。
2、drop PDB
關閉並且拔出PDB後才可以進行刪除,刪除時可以一起刪除資料檔案:
同樣需要連線到CDB$ROOT容器,執行下列語句:
SQL> drop pluggable database pdb_4 keep datafiles;
Pluggable database dropped.
SQL> select name,open_mode from v$pdbs;
NAME OPEN_MODE
------------------------------ ----------
PDB$SEED READ ONLY
PDB_1 READ WRITE
PDB_2 READ WRITE
PDB_3 READ WRITE
這裡使用了keep datafiles保留了PDB_4的資料檔案。另外,也可以使用inluding datafiles徹底刪除PDB的資料檔案。
3、plug an unplugged PDB
plug PDB_4:
SQL> create pluggable database pdb_4_replug using '/home/oracle/unplugged_pdbs/pdb_4.xml' nocopy tempfile reuse;
Pluggable database created.
SQL> select name from v$pdbs;
NAME
------------------------------
PDB$SEED
PDB_1
PDB_2
PDB_3
PDB_4_REPLUG
SQL> select name,open_mode from v$pdbs;
NAME OPEN_MODE
------------------------------ ----------
PDB$SEED READ ONLY
PDB_1 READ WRITE
PDB_2 READ WRITE
PDB_3 READ WRITE
PDB_4_REPLUG MOUNTED
上述create pluggable database語句中,因為資料檔案都在xml檔案指定的位置,且仍使用原來的位置作為新
的pdb的資料檔案的儲存位置,因此沒有包含其他子句。
另外一條plug PDB的語句也可能如下:
CREATE PLUGGABLE DATABASE pdbname
USING '/location/filename.xml'
SOURCE_FILE_NAME_CONVERT=('/location1/','/location2/')
MOVE
FILE_NAME_CONVERT=('/location2/','/location3/')
PATH_PREFIX='/location3/'
STORAGE (MAXSIZE 2G MAX_SHARED_TEMP_SIZE 100M);
這裡xml檔案中指示資料檔案在/location1/中,而實際上資料檔案在/location2/中,且最終我們要將資料檔案
放在/location3/中
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/196700/viewspace-2144023/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Cookie 的新增與刪除Cookie
- Mysql索引的建立與刪除MySql索引
- PostgreSQL:資料庫的建立與刪除SQL資料庫
- elasticsearch(三)----索引建立與刪除Elasticsearch索引
- SQL Cookbook—插入、更新與刪除SQL
- ubuntu環境變數的新增與刪除Ubuntu變數
- 表格的批量重新命名與批量刪除
- SQL Server 觸發器的修改與刪除SQLServer觸發器
- thread在surfaceview中的使用與刪除threadView
- JavaScript 動態新增與刪除元素JavaScript
- [MYSQL] 資料庫建立與刪除MySql資料庫
- oracle db link的檢視建立與刪除Oracle
- Tree樹狀圖的動態增刪查改(下)修改與刪除
- Ubuntu環境變數——新增與刪除Ubuntu變數
- php(js)批量刪除/單個刪除PHPJS
- 檔案的刪除
- whk我【資料刪除】你個【資料刪除】的
- hadoop 資料夾檔案的建立與刪除Hadoop
- React實現表單資料的新增與刪除React
- oracle 快速刪除大批量資料方法(全部刪除,條件刪除,刪除大量重複記錄)Oracle
- 工作293:調節刪除順序刪除
- linux的刪除檔案命令和強制刪除命令Linux
- 【刪除】【Oracle】完美刪除Windows系統上的Oracle軟體OracleWindows
- mySql刪除多個表 刪除多個欄位的SQLMySql
- oracle 快速刪除大批量資料方法(全部刪除,條件刪除,刪除大量重複記錄) 轉Oracle
- 【轉】oracle 快速刪除大批量資料方法(全部刪除,條件刪除,刪除大量重複記錄)Oracle
- 刪除 oracleOracle
- Oracle 12c 建立與刪除CDB、PDBsOracle
- 資料庫 - 索引、基本表建立與刪除資料庫索引
- cache與DB一致性-刪除
- Flask-caching 的快取與刪除 —— 避坑指南Flask快取
- 表管理之二:表資料的插入修改與刪除
- SQLPLUS中HELP幫助的安裝與刪除SQL
- Sqlserver中所有約束的型別,建立、修改與刪除SQLServer型別
- 刪除AIX下的ORACLEAIOracle
- 6.12php對資料庫的刪除和批量刪除PHP資料庫
- oracle rac 12徹底刪除,徹底刪除該死的racOracle
- 儲存系統實現-資料刪除之索引的刪除索引