ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 【SQL*Loader】SQL*Loader实验之(10)--在数据加载时,调用序列给字段赋值

【SQL*Loader】SQL*Loader实验之(10)--在数据加载时,调用序列给字段赋值

原创 Linux操作系统 作者:chicheng_cn421 时间:2011-06-19 16:58:24 0 删除 编辑

【实验内容】
模拟情况:在数据加载时,调用序列(Sequence)给字段赋值


【实验过程】

//(1)先创建一个序列SEQ_DEPT2。

CREATE SEQUENCE SEQ_DEPT2
INCREMENT BY 1
START WITH 1
MAXVALUE 9999999
NOCYCLE
NOCACHE;

---------------------------
SQL> CREATE SEQUENCE SEQ_DEPT2
  2  INCREMENT BY 1
  3  START WITH 1
  4  MAXVALUE 9999999
  5  NOCYCLE
  6  NOCACHE;

序列已创建。

SQL>

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

//(2)看一下数据导入前dept2中表的数据状况。
-------------------------
SQL> select * from dept2;

    DEPTNO DNAME          LOC           ADD_COL_CA
---------- -------------- ------------- ----------
        12 ACCOUNTING     NEW YORK      0
        22 RESEARCH       DALLAS        0
        32 SALES          CHICAGO       0
        42 OPERATIONS     BOSTON        0

已选择4行。

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

//(3)做成dept2_ShiYan10_01.dat数据文件。
内容如下:※这里面没有最后新追加的非空字段ADD_COL_CANNOT_NULL的数据。
----------------------------------------
13,ACCOUNTING,NEW YORK
23,RESEARCH,DALLAS
33,SALES,CHICAGO
43,OPERATIONS,BOSTON
----------------------------------------

//(4)做成sqlloder导入用控制文件dept2_ShiYan10_01.ctl
内容如下:
----------------------------------------
LOAD DATA
INFILE 'dept2_ShiYan10_01.dat'
BADFILE 'dept2_ShiYan10_01.bad'
INTO TABLE dept2
APPEND
FIELDS TERMINATED BY ","
TRAILING NULLCOLS  -- 表的字段没有对应的值时允许为空
( DEPTNO,
  DNAME,
  LOC,
  ADD_COL_CANNOT_NULL "SEQ_DEPT2.NEXTVAL"  -- 像这个样子引用序列即可。
)
----------------------------------------

//(5)启动并执行sqlloader。

sqlldr scott/tiger control="dept2_ShiYan10_01.ctl"  log="dept2_ShiYan10_01.log"

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

D:\Oracle学习\test\sqlloader\实验10>sqlldr scott/tiger control="dept2_ShiYan10_01.ctl"  log="dept2_ShiYan10_01.log"

SQL*Loader: Release 10.2.0.1.0 - Production on 星期日 6月 19 16:28:06 2011

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

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

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

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

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

SQL*Loader: Release 10.2.0.1.0 - Production on 星期日 6月 19 16:28:06 2011

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

控制文件:      dept2_ShiYan10_01.ctl
数据文件:      dept2_ShiYan10_01.dat
  错误文件:    dept2_ShiYan10_01.bad
  废弃文件:    未作指定
 
(可废弃所有记录)

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

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

   列名                        位置      长度  中止 包装数据类型
------------------------------ ---------- ----- ---- ---- ---------------------
DEPTNO                              FIRST     *   ,       CHARACTER           
DNAME                                NEXT     *   ,       CHARACTER           
LOC                                  NEXT     *   ,       CHARACTER           
ADD_COL_CANNOT_NULL                  NEXT     *   ,       CHARACTER           
    列的 SQL 串: "SEQ_DEPT2.NEXTVAL"


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


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

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

从 星期日 6月  19 16:28:06 2011 开始运行
在 星期日 6月  19 16:28:06 2011 处运行结束

经过时间为: 00: 00: 00.38
CPU 时间为: 00: 00: 00.22

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

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

    DEPTNO DNAME          LOC           ADD_COL_CA
---------- -------------- ------------- ----------
        12 ACCOUNTING     NEW YORK      0
        22 RESEARCH       DALLAS        0
        32 SALES          CHICAGO       0
        42 OPERATIONS     BOSTON        0
        13 ACCOUNTING     NEW YORK      1
        23 RESEARCH       DALLAS        2
        33 SALES          CHICAGO       3
        43 OPERATIONS     BOSTON        4

已选择8行。

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

 

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

请登录后发表评论 登录
全部评论

注册时间:2011-03-05

  • 博文量
    261
  • 访问量
    377971