欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle的SQLLDR用法簡介

 更新時間:2023年07月03日 10:01:01   作者:OO好久不見OO  
這篇文章主要介紹了Oracle的SQLLDR用法簡介,SQL*Loader是oracle的高速批量數(shù)據(jù)加載工具,這是一個非常有用的工具,可用于從多種平面文件格式向Oracle數(shù)據(jù)庫中加載數(shù)據(jù),SQLLDR可以在極短的時間內(nèi)加載數(shù)量龐大的數(shù)據(jù),需要的朋友可以參考下

SQLLDR導(dǎo)入

1.簡介

SQL*LOADER是ORACLE的數(shù)據(jù)加載工具,通常用來將操作系統(tǒng)文件(數(shù)據(jù))遷移到ORACLE數(shù)據(jù)庫中。SQL*LOADER是大型數(shù)據(jù)倉庫選擇使用的加載方法,因為它提供了最快速的途徑(DIRECT,PARALLEL)。

2.語法和參數(shù)

語法: SQLLDR keyword=value [,keyword=value,...];

Sqlldr 參數(shù)一覽

Keyword默認(rèn)值描述
useridORACLE 用戶名/口令      
control控制文件名
log日志文件名
bad錯誤文件名
data數(shù)據(jù)文件名
discard廢棄文件名
discardmax全部允許廢棄的文件的數(shù)目
skip0要跳過的邏輯記錄的數(shù)目
load全部要加載的邏輯記錄的數(shù)目
errors允許的錯誤的數(shù)目
rows常規(guī):64  默認(rèn)路徑:全部常規(guī)路徑綁定數(shù)組中或直接路徑保存數(shù)據(jù)間的行數(shù)
bindsize256000常規(guī)路徑綁定數(shù)組的大小
silent運行過程中隱藏消息
directFALSE使用直接路徑
parfile參數(shù)文件: 包含參數(shù)說明的文件的名稱
parallelFALSE執(zhí)行并行加載
file執(zhí)行文件
skip_unusable_indexesFALSE不允許/允許使用無用的索引或索引分區(qū)
skip_index_maintenanceFALSE沒有維護索引, 將受到影響的索引標(biāo)記為無用
commit_discontinuedFALSE提交加載中斷時已加載的行
readsize1048576讀取緩沖區(qū)的大小
external_tableNOT_USED使用外部表進行加載; NOT_USED, GENERATE_ONLY, EXECUTE
columnarrayrows5000直接路徑列數(shù)組的行數(shù)
streamsize256000直接路徑流緩沖區(qū)的大小 (以字節(jié)計)
multithreading在直接路徑中使用多線程
resumableFALSE啟用或禁用當(dāng)前的可恢復(fù)會話
resumable_name有助于標(biāo)識可恢復(fù)語句的文本字符串
resumable_timeout7200RESUMABLE 的等待時間 (以秒計)
date_cache1000日期轉(zhuǎn)換高速緩存的大小 (以條目計)

3. 范例

利用PLSQL生成測試數(shù)據(jù)cux_sqlldr_test.txt

BEGIN
? FOR iIN1..100
??? LOOP
????? IFMOD(i,2)=1THEN
??????? dbms_output.put_line('"'||i||'","column1_'||i||'",'||'"column2_'||i||'",'||'"column3_'||i||'",'||'"show_column_'||i||'",'||'"hide_column_'||i||'","2017-01-01"');?
????? ELSE
??????? dbms_output.put_line('"'||i||'","column1_'||i||'", ,'||'"column3_'||i||'",'||'"show_column_'||i||'",'||'"hide_column_'||i||'"');?????????
????? ENDIF;
??? ENDLOOP;
END;

建表

CREATETABLE cux.cux_sqlldr_test
(line_num?NUMBER,
?seq_num NUMBER,
?column1 VARCHAR2(30),
?column2 VARCHAR2(30)NOTNULL,
?column3 VARCHAR2(30)DEFAULT'column2',
?show_column VARCHAR2(30),
?hide_column VARCHAR2(30),
?creation_date DATE
);
CREATEORREPLACE?SYNONYM apps.cux_sqlldr_test?FOR cux.cux_sqlldr_test;
CREATESEQUENCE cux.cux_sqlldr_test_sSTARTWITH10001;
CREATEORREPLACESYNONYM apps.cux_sqlldr_test_s FOR cux.cux_sqlldr_test_s;

4.Sqlldr 有兩種使用方式

(1)在控制文件中包涵數(shù)據(jù).

創(chuàng)建一個文件命名為cux_sqlldr_test.ctl,在服務(wù)器下創(chuàng)建目錄Sqlldr,在sqlldr下創(chuàng)建log和bad文件夾,

上傳cux_sqlldr_test.ctl至服務(wù)器 ,如下圖所示: 

cux_sqlldr_test.ctl內(nèi)容如下:

OPTIONS (skip=3,rows=128)
load data?????
CHARACTERSET ZHS16GBK??
infile? *??????
badfile? "/u02/ebsuat/app/fs2/EBSapps/appl/cux/12.0.0/sqlldr/bad/cux_sqlldr_test.bad"
discardfile? "/u02/ebsuat/app/fs2/EBSapps/appl/cux/12.0.0/sqlldr/bad/cux_sqlldr_test.disc"?
TRUNCATE into table cux_sqlldr_test?
WHEN column1 != "column1_1"
Fields terminated by ","
Optionally enclosed by '"'
TRAILING NULLCOLS?
(
line_num? RECNUM ,
seq_num? "cux_sqlldr_test_s.nextval" ,
column1 ,
column2 ,
column3 NULLIF (column3="column3_4"),
show_column "UPPER(:show_column)" ,
hide_column? FILLER ,?
creation_date? DATE? 'YYYY-MM-DD' "CASE WHEN :creation_date is null THEN TO_CHAR(sysdate,'YYYY-MM-DD')? ELSE :creation_date END"
)
BEGINDATA
"1","column1_1","column2_1","column3_1","show_column_1","hide_column_1","2017-01-01"
"2","column1_2", ,"column3_2","show_column_2","hide_column_2"
"3","column1_3","column2_3","column3_3","show_column_3","hide_column_3","2017-01-01"
"4","column1_4", ,"column3_4","show_column_4","hide_column_4"
"5","column1_5","column2_5","column3_5","show_column_5","hide_column_5","2017-01-01"
"6","column1_6", ,"column3_6","show_column_6","hide_column_6"
"7","column1_7","column2_7","column3_7","show_column_7","hide_column_7","2017-01-01"
"8","column1_8", ,"column3_8","show_column_8","hide_column_8"
"9","column1_9","column2_9","column3_9","show_column_9","hide_column_9","2017-01-01"
"10","column1_10", ,"column3_10","show_column_10","hide_column_10"

運行命令

sqlldr userid=apps/appsjiahuicontrol=/u02/ebsuat/app/fs2/EBSapps/appl/cux/12.0.0/sqlldr/file/cux_sqlldr_test.ctl  log=$CUX_TOP/sqlldr/file/cux_sqlldr_test.log

查看結(jié)果

查看表

由上圖可以看出,運行命令后,在file文件夾下生成了cux_sqlldr_test.log,在bad下生成了cux_sqlldr_test.bad,在表中生成了3條記錄,下面分析一下cux_sqlldr_test.ctl的內(nèi)容和結(jié)果

代碼說明
OPTIONS (skip=3,rows=128)sqlldr 的內(nèi)容可以寫在cotrol文件load_data的前面,此處跳過前3行,每次提交128行
load data     加載數(shù)據(jù)
CHARACTERSET ZHS16GBK  字符集編碼(如果出現(xiàn)亂碼要考慮一下)
infile  *      加載的文件,* 表示本文件
badfile 錯誤的數(shù)據(jù)所放的文件(校驗錯誤)
discardfile丟棄的數(shù)據(jù)放的路徑(記錄的格式錯誤或過濾行)
TRUNCATE into table cux_sqlldr_test 先TRUNCATE  cux_sqlldr_test再將記錄插入表
WHEN column1 != "column1_1"過濾行,對于值為column1_1的行過濾
Fields terminated by ","多個字段間用“,”隔開
Optionally enclosed by '"'單個字段用“"”,“"”開始結(jié)束
TRAILING NULLCOLS 對于值為空的字段允許為空
(line_num  RECNUM序號,自動生成,并不取自數(shù)據(jù)
seq_num  "cux_sqlldr_test_s.nextval"取每條記錄的第一個字段,此處應(yīng)為1..10,但是這里賦值序列。

表2

代碼說明
column1column1
column2column2,表定義為非空字段,雖然上面允許為空,但是如果該值為空,不能插入表種
column3 NULLIF (column3="column3_4")column3="column3_4"時候默認(rèn)為空
show_column "UPPER(:show_column)" 大寫列(調(diào)用UPPER大寫函數(shù))
hide_column  FILLERFILLER 隱藏列
creation_date  DATE  'YYYY-MM-DD'"CASE WHEN :creation_date is null THENTO_CHAR(sysdate,'YYYY-MM-DD') ELSE :creation_date END"日期類型,格式為YYYY-MM-DD,為空的時候取系統(tǒng)日期
BEGINDATA數(shù)據(jù)開始
*******數(shù)據(jù)內(nèi)容,默認(rèn)每行一條記錄

從日志可以看出7條數(shù)據(jù)中,4條記錄無法沒導(dǎo)入的原因。

查看cux_sqlldr_test.bad,其中記錄4條錯誤的數(shù)據(jù)。

(2)在控制文件中不包涵數(shù)據(jù).

上傳cux_sqlldr_test.txt,cux_sqlldr_test.ctl至服務(wù)器,cux_sqlldr_test.txt由上面PLSQL腳本生成,cux_sqlldr_test.ctl如下

OPTIONS (skip=3,rows=128)
load data???? 
CHARACTERSET ZHS16GBK??
infile? "/u02/ebsuat/app/fs2/EBSapps/appl/cux/12.0.0/sqlldr/file/cux_sqlldr_test.txt"?????
badfile? "/u02/ebsuat/app/fs2/EBSapps/appl/cux/12.0.0/sqlldr/bad/cux_sqlldr_test.bad"
discardfile "/u02/ebsuat/app/fs2/EBSapps/appl/cux/12.0.0/sqlldr/bad/cux_sqlldr_test.disc"?
TRUNCATE into table cux_sqlldr_test?
WHEN column1 != "column1_4"
Fields terminated by ","
Optionally enclosed by '"'
TRAILING NULLCOLS?
(
line_num? RECNUM ,
seq_num? "cux_sqlldr_test_s.nextval" ,
column1 ,
column2 "nvl(:column2,'***')",
column3 NULLIF (column3="column3_4"),
show_column "UPPER(:show_column)" ,
hide_column? FILLER ,?
creation_date? DATE? 'YYYY-MM-DD' "CASE WHEN :creation_date is null THEN TO_CHAR(sysdate,'YYYY-MM-DD')? ELSE :creation_date END"
)

運行命令

sqlldr userid=apps/appsjiahuicontrol=/u02/ebsuat/app/fs2/EBSapps/appl/cux/12.0.0/sqlldr/file/cux_sqlldr_test.ctl  log=$CUX_TOP/sqlldr/file/cux_sqlldr_test.log

100條數(shù)據(jù)由于skip = 3 從第4條開始處理變成97條,第四條數(shù)據(jù)由于WHEN column1 != "column1_4"

被丟棄在bad的cux_sqlldr_test.disc路徑下,沒有錯誤數(shù)據(jù)。查看表共96條數(shù)據(jù),如下圖所示:

 column2 "nvl(:column2,'***')", 對于 column2默認(rèn)為 “***” .

其他

此外,sqlload可以實現(xiàn)同時加載多個文件,同時把數(shù)據(jù)加載到多個表。

到此這篇關(guān)于Oracle的SQLLDR用法簡介的文章就介紹到這了,更多相關(guān)Oracle SQLLDR內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Oracle數(shù)據(jù)遷移MySQL的三種簡單方法

    Oracle數(shù)據(jù)遷移MySQL的三種簡單方法

    對于許多企業(yè)而言,遷移數(shù)據(jù)庫時最大的挑戰(zhàn)之一是如何從一個數(shù)據(jù)庫平臺順利遷移到另一個平臺,下面這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)遷移MySQL的三種簡單方法,需要的朋友可以參考下
    2023-06-06
  • oracle 使用遞歸的性能提示測試對比

    oracle 使用遞歸的性能提示測試對比

    先遞歸循環(huán)出某個文件夾下面的所有的文件夾以及文件在關(guān)聯(lián)文件表查找文件的內(nèi)容這是正確的做法,感興趣的朋友可以了解下,或許對你學(xué)習(xí)oracle遞歸有所幫助
    2013-02-02
  • 解決ORA-01747:user.table.column,table.column或列說明無效

    解決ORA-01747:user.table.column,table.column或列說明無效

    這篇文章主要介紹了解決ORA-01747:user.table.column,table.column或列說明無效的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • oracle12C安裝步驟(圖文詳解)

    oracle12C安裝步驟(圖文詳解)

    這篇文章主要介紹了oracle12C安裝步驟(圖文詳解),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • Oracle RMAN還原時set newname文件名有空格報錯的解決方法

    Oracle RMAN還原時set newname文件名有空格報錯的解決方法

    數(shù)據(jù)庫備份還原是我們?nèi)粘i_發(fā)少不了的一個功能,但如果一不注意估計就會有問題,下面這篇文章主要給大家介紹了關(guān)于Oracle RMAN還原時set newname文件名有空格報錯的解決方法,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • 常見數(shù)據(jù)庫系統(tǒng)比較  Oracle數(shù)據(jù)庫

    常見數(shù)據(jù)庫系統(tǒng)比較 Oracle數(shù)據(jù)庫

    常見數(shù)據(jù)庫系統(tǒng)比較 Oracle數(shù)據(jù)庫...
    2007-03-03
  • oracle數(shù)據(jù)庫在客戶端建立dblink語法

    oracle數(shù)據(jù)庫在客戶端建立dblink語法

    oracle服務(wù)器沒有建立目標(biāo)數(shù)據(jù)庫的TNS時,在客戶端(有權(quán)限的情況下)建立dblink語法如下,有需求的朋友可以參考下哈
    2013-05-05
  • Oracle數(shù)據(jù)庫tnsnames.ora文件的作用和配置

    Oracle數(shù)據(jù)庫tnsnames.ora文件的作用和配置

    這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫tnsnames.ora文件的作用和配置,tnsnames.ora 是一個oracle數(shù)據(jù)庫網(wǎng)絡(luò)配置文件,通過這個配置文件才能建立對數(shù)據(jù)庫的連接,需要的朋友可以參考下
    2024-06-06
  • Oracle面試題及答案超全整理

    Oracle面試題及答案超全整理

    我們在Oracle數(shù)據(jù)庫上面實現(xiàn)更多運算任務(wù)時,有可能會碰到有關(guān)Oracle的一些筆試和面試題,讓大家更加有效地掌握Oracle數(shù)據(jù)庫的知識,趕超比自己職業(yè)前景更好的人,下面這篇文章主要給大家介紹了關(guān)于Oracle面試題及答案整理的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • Oracle數(shù)據(jù)表分區(qū)的策略

    Oracle數(shù)據(jù)表分區(qū)的策略

    Oracle數(shù)據(jù)表分區(qū)的策略...
    2007-03-03

最新評論