【SQL*Loader】SQL*Loader实验之(17)--灵活处理数据中存在回车换行符的情况。


【实验内容】
模拟情况:今天模拟一种比较棘手的情况--数据中存在回车换行符("\n")的情况。
这种情况其实解决起来并不麻烦,只需要在控制文件中,将相关列字段指定用标准换行符chr(10)替换掉数据中"\n"字符即可。

※在默认情况下,标准换行符也是SQLLDR识别数据行结束的标志符,因此要将含换行符的数据加载到表中需要用chr(10)来替换一下。

例如:
----------------------------------------
LOAD DATA
INFILE 'dept2_ShiYan17_01.dat'
BADFILE 'dept2_ShiYan17_01.bad'
DISCARDFILE 'dept2_ShiYan17_01.dis'
INTO TABLE dept2
APPEND
FIELDS TERMINATED BY ","
(  DEPTNO,
   DNAME,
   LOC "replace(:LOC, '\\n',chr(10))"  -- :LOC 是用来引用LOC字段的数据,'\\n' 使用了转义符'\',chr(10) 为标准换行符。
   )
----------------------------------------


【实验过程】
//(1)数据加载前的dept2中的数据状况。

-------------------------
SQL> select * from dept2;

未选定行

SQL>
-------------------------

//(2)做成数据文件dept2_ShiYan17_01.dat
----------------------------------------
10,ACCOUNTING,NEW YORK
20,RESEARCH,DALLAS
30,SALES,CHICAGO
40,OPERATIONS,BOSTON\nGOOD
----------------------------------------

//(3)做成sqlloder导入用控制文件dept2_ShiYan17_01.ctl
内容如下:
----------------------------------------
LOAD DATA
INFILE 'dept2_ShiYan17_01.dat'
BADFILE 'dept2_ShiYan17_01.bad'
DISCARDFILE 'dept2_ShiYan17_01.dis'
INTO TABLE dept2
APPEND
FIELDS TERMINATED BY ","
(  DEPTNO,
   DNAME,
   LOC "replace(:LOC, '\\n',chr(10))"  -- :LOC 是用来引用LOC字段的数据,'\\n' 使用了转义符'\',chr(10) 为标准换行符。
   )
----------------------------------------

//(4)启动并执行sqlloader。
sqlldr scott/tiger control="dept2_ShiYan17_01.ctl"  log="dept2_ShiYan17_01.log"

--------------------
D:\Oracle学习\test\sqlloader\实验17>sqlldr scott/tiger control="dept2_ShiYan17_01.ctl"  log="dept2_ShiYan17_01.log"
SQL*Loader: Release 10.2.0.1.0 - Production on 星期六 6月 25 21:45:20 2011
Copyright (c) 1982, 2005, Oracle.  All rights reserved.

达到提交点 - 逻辑记录计数 3
达到提交点 - 逻辑记录计数 4

D:\Oracle学习\test\sqlloader\实验17>

--------------------

产生的Log文件
--------------------

SQL*Loader: Release 10.2.0.1.0 - Production on 星期六 6月 25 21:45:20 2011

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

控制文件:      dept2_ShiYan17_01.ctl
数据文件:      dept2_ShiYan17_01.dat
  错误文件:    dept2_ShiYan17_01.bad
  废弃文件:    dept2_ShiYan17_01.dis
(可废弃所有记录)

要加载的数: ALL
要跳过的数: 0
允许的错误: 50
绑定数组: 64 行, 最大 256000 字节
继续:    未作指定
所用路径:       常规

表 DEPT2,已加载从每个逻辑记录
插入选项对此表 APPEND 生效

   列名                        位置      长度  中止 包装数据类型
------------------------------ ---------- ----- ---- ---- ---------------------
DEPTNO                              FIRST     *   ,       CHARACTER           
DNAME                                NEXT     *   ,       CHARACTER           
LOC                                  NEXT     *   ,       CHARACTER           
    列的 SQL 串: "replace(:LOC, '\n',chr(10))"


表 DEPT2:
  4 行 加载成功。
  由于数据错误, 0 行 没有加载。
  由于所有 WHEN 子句失败, 0 行 没有加载。
  由于所有字段都为空的, 0 行 没有加载。


为绑定数组分配的空间:                 49536 字节 (64 行)
读取   缓冲区字节数: 1048576

跳过的逻辑记录总数:          0
读取的逻辑记录总数:             4
拒绝的逻辑记录总数:          0
废弃的逻辑记录总数:        0

从 星期六 6月  25 21:45:20 2011 开始运行
在 星期六 6月  25 21:45:20 2011 处运行结束

经过时间为: 00: 00: 00.65
CPU 时间为: 00: 00: 00.19

--------------------

执行后 dept2中的数据状况。
--------------------
SQL> select * from dept2;

    DEPTNO DNAME          LOC
---------- -------------- -------------
        10 ACCOUNTING     NEW YORK
        20 RESEARCH       DALLAS
        30 SALES          CHICAGO
        40 OPERATIONS     BOSTON
                          GOOD


已选择4行。

SQL>
--------------------
以上。

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/20335819/viewspace-700735/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/20335819/viewspace-700735/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值