亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

細致入微:如何使用數據泵導出表的部分列數據

發布時間:2020-08-11 08:50:42 來源:ITPUB博客 閱讀:127 作者:數據和云 欄目:關系型數據庫

編者按

云和恩墨大講堂社群(本文底部有入群方式)里有人提出一個需求:一張表數據量很大,如何只導出其中一部分列?云和恩墨CTO、Oracle ACE總監、ACOUG核心專家楊廷琨老師使用了數據泵的方式,細致入微地解釋了過程并給出具體的代碼實現。數據和云(ID:OraNews)獨家發布,以饗讀者。

以下為正文

無論是老版本exp還是數據泵expdp,Oracle都提供了QUERY的功能,這使得查詢表中部分記錄的功能可以實現,但是QUERY只能過濾行,而不能過濾列,Oracle數據泵會讀取表中全部列的。

在12c中,Oracle為數據泵提供了VIEW功能,使得導出的時候可以根據視圖的定義來導出表中的數據:

SQL>select banner from v$version; 
BANNER--------------------------------------------------------------------------------
OracleDatabase 18c Enterprise Edition Release 18.0.0.0.0 - Production 
SQL>CREATE TABLE T_TABLES AS SELECT * FROM ALL_TABLES;

 (左右滑動查看代碼部分,下同

表已創建。

SQL>create view v_tables as select owner, table_name, tablespace_name from t_tableswhere owner not in ('SYS');

 視圖已創建。

利用數據泵的VIEWS_AS_TABLES參數可以直接導出視圖對應的表數據:

C:\Users\yangt>expdpc##u1 directory=d_output dumpfile=t_tab_view views_as_tables=v_tables 

Export:Release 18.0.0.0.0 - Production on 星期二 2月 26 13:37:312019

Version18.3.0.0.0

Copyright(c) 1982, 2018, Oracle and/or its affiliates. All rights reserved.

口令:連接到: Oracle Database 18c Enterprise Edition Release 18.0.0.0.0 -Production

警告: 連接到容器數據庫的根或種子時通常不需要 Oracle Data Pump 操作。

啟動 "C##U1"."SYS_EXPORT_TABLE_01":  c##u1/******** 
directory=d_outputdumpfile=t_tab_view views_as_tables=v_tables
處理對象類型 TABLE_EXPORT/VIEWS_AS_TABLES/TABLE_DATA
處理對象類型 TABLE_EXPORT/VIEWS_AS_TABLES/TABLE
. . 導出了"C##U1"."V_TABLES"                          
8.289 KB      71 行
已成功加載/卸載了主表"C##U1"."SYS_EXPORT_TABLE_01"
******************************************************************************
C##U1.SYS_EXPORT_TABLE_01的轉儲文件集為: 
D:\TEMP\T_TAB_VIEW.DMP
作業 "C##U1"."SYS_EXPORT_TABLE_01" 已于 星期二 2月 26 13:37:40 2019 elapsed 0 00:00:06 成功完成

雖然是通過視圖導出的,但是數據泵把它當作一個表來處理,因此這個dump文件是可以直接導入到數據庫中變成表的:

SQL>drop view v_tables;

視圖已刪除。

完成導入操作:

C:\Users\yangt>impdpc##u1 directory=d_output dumpfile=t_tab_view full=y 
Import:Release 18.0.0.0.0 - Production on 星期二 2月 26 14:33:022019
Version18.3.0.0.0 Copyright(c) 1982, 2018, Oracle and/or its affiliates. 
All rights reserved.
口令: 
連接到: Oracle Database 18c Enterprise Edition Release 18.0.0.0.0 -Production

警告: 連接到容器數據庫的根或種子時通常不需要 Oracle Data Pump 操作。

已成功加載/卸載了主表"C##U1"."SYS_IMPORT_FULL_01"
啟動 "C##U1"."SYS_IMPORT_FULL_01":  c##u1/******** directory=d_outputdumpfile=t_tab_view full=y
處理對象類型 TABLE_EXPORT/VIEWS_AS_TABLES/TABLE處理對象類型 TABLE_EXPORT/VIEWS_AS_TABLES/TABLE_DATA
. . 導入了"C##U1"."V_TABLES"                          
8.289 KB      71 行
作業 "C##U1"."SYS_IMPORT_FULL_01" 已于 星期二 2月 26 14:33:07 2019 elapsed 0 00:00:02 成功完成

查詢表數據:

SQL>select count(*) from v_tables;
   
COUNT(*)
----------        
71 
SQL>select table_name, tablespace_name from user_tables where table_name ='V_TABLES'; 
TABLE_NAME                     
TABLESPACE_NAME------------------------------------------------------------
V_TABLES                       USERS

這個功能是12c的特新特,如果是12c之前的版本,可以考慮使用ORACLE_DATAPUMP類型的外部表來實現:

SQL>create table t_external_tables (owner, table_name, tablespace_name)organization external  
2 (type oracle_datapump  
3 default directory d_output  
4 location ('external_table.dp'))  
5  asselect owner, table_name, tablespace_name from t_tables where owner not in('SYS');

表已創建。

通過將外部表導出的 external_table.dp 文件拷貝到目標環境對應的目錄下,根據上面的定義重建外部表,注意目標環境創建過程由于已經拷貝了導出的數據,因此語法截至到 location 語句就結束了,不要再包含 as select 部分。

SQL>create table t_target_ext_tab (owner varchar2(30), table_name varchar2(128),tablespace_name varchar2(30))  
2 organization external  
3 (type oracle_datapump  
4 default directory d_output  5 location ('external_table.dp'));

表已創建。

SQL>select count(*) from t_target_ext_tab;   
COUNT(*)----------        
71 
SQL>col table_name for a30SQL>select * from t_target_ext_tab where owner = 'SYSTEM'; 
OWNER                          TABLE_NAME                     TABLESPACE_NAME
------------------------------------------------------------ ------------------------------
SYSTEM                         OL$SYSTEM                         OL$HINTS
SYSTEM                         OL$NODES
SYSTEM                         HELP                    
       SYSTEM

所以對于11g和10g的版本,也可以不通過新建表,然后拷貝數據的方式來實現數據的導出和轉移。但是如果是9i及以前的版本,那么要不然通過建表然后exp導出的方式,要不然自己寫程序實現數據的導出吧。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

游戏| 平泉县| 勐海县| 宁武县| 贵溪市| 忻州市| 左云县| 汉中市| 茶陵县| 镇江市| 思南县| 额尔古纳市| 肇源县| 庄浪县| 建宁县| 云南省| 台北市| 花垣县| 瓮安县| 酒泉市| 陵川县| 建平县| 莱阳市| 正阳县| 壤塘县| 姚安县| 米林县| 井陉县| 阿合奇县| 读书| 兴文县| 德庆县| 焦作市| 齐河县| 巴马| 吴堡县| 宝兴县| 谢通门县| 游戏| 团风县| 台北县|