• 【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

  • 相关阅读:
    POJ2142:The Balance——题解
    POJ1061:青蛙的约会——题解
    接口测试结束后的小结
    接口测试结束后的小结
    如何进行需求测试/需求评审
    如何进行需求测试/需求评审
    测试人员掌握代码的重要性
    测试人员掌握代码的重要性
    测试人员掌握代码的重要性
    软件自动化测试开发-开班啦
  • 原文地址:https://www.cnblogs.com/heyang78/p/16091963.html
Copyright © 2020-2023  润新知