oracle通過sqlldr導入文本數據


 執行命令:

sqlldr userid=epay/epay control=/tmp/test.ctl log=/tmp/test.log data=/tmp/test.csv rows=10
命令參數:
userid -- Oracle 的 username/password[@servicename]
control -- 控制文件,可能包含表的數據
log -- 記錄導入時的日志文件,默認為 控制文件(去除擴展名).log
bad -- 壞數據文件,默認為 控制文件(去除擴展名).bad
data -- 數據文件,一般在控制文件中指定。用參數控制文件中不指定數據文件更適於自動操作
errors -- 允許的錯誤記錄數,可以用他來控制一條記錄都不能錯
rows -- 多少條記錄提交一次,默認為 64
skip -- 跳過的行數,比如導出的數據文件前面幾行是表頭或其他描

 

 ctl腳本

load data
append into table "T_USER_CTRL"  -- 操作類型
  --
1) insert     --為缺省方式,在數據裝載開始時要求表為空
  -- 2) append  --在表中追加新記錄
  -- 3) replace  --刪除舊記錄(用 delete from table 語句),替換成新裝載的記錄
  -- 4) truncate --刪除舊記錄(用 truncate table 語句),替換成新裝載的記錄
fields terminated by
' ' -- 數據分隔符 trailing nullcols (ID,CUST_NUM,CARD_NO,MER_DAY_AMT,MER_DAY_AMT_DATE DATE "YYYY-MM-DD HH24")

 

CSV數據

1 606110048163089 6218710000005136 3 2017-01-01
1 606110048163089 6218710000005136 3 2017-01-01
1 606110048163089 6218710000005136 3 2017-01-01
1 606110048163089 6218710000005136 3 2017-01-01

 

復雜實例:

數據:

insert into users values(1,'Unmi',3,sysdate); 
insert into users values(2,NULL,5,to_date('2008-10-15','YYYY-MM-DD')); 
insert into users values(3,'隔葉黃鶯',8,to_date('2009-01-02','YYYY-MM-DD')); 
insert into users values(4,'Kypfos',NULL,NULL); 
insert into users values(5,'不知秋',1,to_date('2008-12-23','YYYY-MM-DD'));

"   ","USER_ID","USER_NAME","LOGIN_TIMES","LAST_LOGIN"
"1","1","Unmi","3","2009-1-5 20:34:44"
"2","2","","5","2008-10-15"
"3","3","隔葉黃鶯","8","2009-1-2"
"4","4","Kypfos","",""
"5","5","不知秋","1","2008-12-23"

 

CTL腳本(數據存放在腳本中也可分離出)

OPTIONS (skip=1,rows=128-- sqlldr 命令顯示的選項可以寫到這里邊來,skip=1 用來跳過數據中的第一行 
LOAD DATA 
INFILE *  -- 因為數據同控制文件在一起,所以用 * 表示 
append    -- 這里用了 append 來操作,在表 users 中附加記錄  
INTO TABLE users 
when LOGIN_TIMES<>'8'  -- 還可以用 when 子句選擇導入符合條件的記錄 
Fields terminated by ","
trailing nullcols 

  virtual_column FILLER, --跳過由 PL/SQL Developer 生成的第一列序號 
  user_id "user_seq.nextval", --這一列直接取序列的下一值,而不用數據中提供的值 
  user_name "'Hi '||upper(:user_name)",--,還能用SQL函數或運算對數據進行加工處理 
  login_times terminated by ",", NULLIF(login_times='NULL'--可為列單獨指定分隔符 
  last_login DATE "YYYY-MM-DD HH24:MI:SS" NULLIF (last_login="NULL") -- 當字段為"NULL"時就是 NULL 

BEGINDATA --數據從這里開始 
   ,USER_ID,USER_NAME,LOGIN_TIMES,LAST_LOGIN 
1,1,Unmi,3,2009-1-5 20:34 
2,2,Fantasia,5,2008-10-15 
3,3,隔葉黃鶯,8,2009-1-2 
4,4,Kypfos,NULL,NULL
5,5,不知秋,1,2008-12-23

 

執行命令

sqlldr user/passwd@dbservice control=users.ctl

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM