【Oracle】使用sqlldr命令行从csv文件获得数据导入Oracle数据库某表中,如果有数据包括逗号,该怎么办?

文字包括逗号很正常,但这样的csv数据导入表的话需要一点特殊处理,否则就会出错。本文就是说明特殊处理的步骤的。

 

【目标表结构】

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

【csv文件内容】(emp42.csv)

1,'andy,a',23,'2022-04-02 12:12:12'
2,'bill,b,B',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')

上面值得注意的地方已经用颜色标识出来,蓝色一句意味着字段之间用逗号分隔,红色一句表示可选包纳符号是单引号,其中的单斜杠表示转义。

【执行过程】

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:41:41 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,a                       23
02-4月 -22 12.12.12.000000 下午

         2 bill,b,B                     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 下午
复制代码

上面用颜色标示的部分说明,使用单引号包括字段内容后,文本中的逗号没有对字段内容造成不利影响。

【参考资料】:

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

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

END

 

posted @   逆火狂飙  阅读(474)  评论(1编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2020-04-02 经典SQL问题:Top 10%
2020-04-02 区间查询与等效minus查询
2018-04-02 【pyhon】nvshens按目录图片批量下载爬虫1.00(多线程版)
2018-04-02 【Canvas与密铺】90年代马赛克密铺效果 1920x1080
2015-04-02 【Canvas与化学】铁元素图标
2015-04-02 上传项目至svn服务器,从svn上获取项目
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示