【Oracle】使用sqlldr命令行從csv文件獲得數據導入Oracle數據庫某表中,如果有字段是timestamp類型,數據是時間格式 該如何?


在拙文 https://www.cnblogs.com/heyang78/p/16021687.html 里提到過使用sqlldr從csv文件里提取數據進表的操作,但當時沒想到數據為時間戳,字段為timestamp類型的問題。果然在實際運用過程中就出現了問題,於是綜合網上的解決方案便有了下文。提醒一下,文件名中出現的42字樣意味着4月2日,即今天。

 

【要接受數據的目標表】

create table emp_42(
    id number(12),
    name nvarchar2(10),
    age number(3),
    cdate timestamp
)

注意其第四個字段為timestamp類型,它的處理和一般的number、varchar2、nvarchar2類型字段可多一道手續。

 

【准備塞入目標表的csv文件內容】文件名:emp42.csv

1,andy,23,'2022-04-02 12:12:12'
2,bill,24,'2022-04-02 13:13:13'
3,cindy,25,'2022-04-02 14:14:14'
4,douglas,26,'2022-04-02 15:15:15'

可以見到,第四列數據用單引號包了起來,這是和其它三個字段不一樣的地方。

 

【ctl文件內容】文件名:emp42.ctl

options(skip=0,BINDSIZE=20971520, ROWS=10000, READSIZE=20971520, ERRORS=999999999)
load data
infile 'c:\temp1\emp42.csv'
insert into table "EMP_42"
fields terminated by ','  
Optionally enclosed by '\''  
(id,name,age,cdate timestamp 'yyyy-mm-dd hh24:mi:ss')

大家注意最后一行,cdate字段名后多了類型timesatmp和用單引號包起來的日期格式,這些文字是用來幫助oracle識別csv文件中的第四個字段的。

 

如此操作后,就可以導入了:

C:\temp1>sqlldr userid=luna/1234@127.0.0.1:1521/orcl control=emp42.ctl

SQL*Loader: Release 11.2.0.1.0 - Production on 星期六 4月 2 14:05:21 2022

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

達到提交點 - 邏輯記錄計數 3
達到提交點 - 邏輯記錄計數 4

 

導入完畢后看看數據庫情況:

SQL> select * from emp_42;

        ID NAME                        AGE
---------- -------------------- ----------
CDATE
---------------------------------------------------------------------------
         1 andy                         23
02-4月 -22 12.12.12.000000 下午

         2 bill                         24
02-4月 -22 01.13.13.000000 下午

         3 cindy                        25
02-4月 -22 02.14.14.000000 下午


        ID NAME                        AGE
---------- -------------------- ----------
CDATE
---------------------------------------------------------------------------
         4 douglas                      26
02-4月 -22 03.15.15.000000 下午

確如預期。

 

【總結】

要將日期時間導入timestamp字段,csv數據文件里需要用單引號將日期括起來,ctl文件的最后一行,需要指定字段的類型和日期格式,之后導入就順暢了。

 

【參考資料】

1.https://blog.csdn.net/wahwhh/article/details/78435683

2.https://www.cnblogs.com/heyang78/p/16021687.html

END


免責聲明!

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



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