oracle load 用法,Oracle中SQL*LOADER使用方法总结

Oracle数据库中SQL*LOADER使用方法总结(一)

sqlldr 有两种使用方法:

1.使用一个控制文件和一个数据文件。

2.只有一个控制文件,控制文件中包含数据。

分别对两种方法用例子进行说明:

1.使用一个控制文件和一个数据文件。

a.创建表

CREATE TABLE SCOTT.ACT_1

(

ACTNO    INTEGER                              NOT NULL,

ACTKWD   VARCHAR2(10 BYTE)                    NOT NULL,

ACTDESC  VARCHAR2(30 BYTE)                    NOT NULL,

ACTTIME  TIMESTAMP(6)

);

b.控制文件Act_Load.ctl代码如下:

LOAD DATA

INFILE '/home/oracle/rocky/sqlldr/ACT.del'     -------导入数据文件路径及名称

TRUNCATE  ----操作类型,TRUNCATE清除表中原有记录(操作类型还可以为:INSERT/APPEND/REPLACE)

INTO TABLE ACT  ----插入记录表

FIELDS TERMINATED BY ',' ----数据中每列记录用','分隔(还可以用其他符号进行分隔)

OPTIONALLY ENCLOSED BY '"' -------数据中字段用' " '框起

TRAILING NULLCOLS --------表中的字段没有对应值允许插入空值

(ACTNO ,

ACTKWD ,

ACTDESC,

ACTTIME "LOCALTIMESTAMP"   -----------插入localtimestamp

)

c.数据文件ACT.del内容如下:

10,"MANAGE","MANAGE/ADVISE"

20,"ECOST ","ESTIMATE COST"

30,"DEFINE","DEFINE SPECS"

40,"LEADPR","LEAD PROGRAM/DESIGN"

50,"SPECS ","WRITE SPECS"

60,"LOGIC ","DESCRIBE LOGIC"

70,"CODE  ","CODE PROGRAMS"

80,"TEST  ","TEST PROGRAMS"

90,"ADMQS ","ADM QUERY SYSTEM"

100,"TEACH ","TEACH CLASSES"

110,"COURSE","DEVELOP COURSES"

120,"STAFF ","PERS AND STAFFING"

130,"OPERAT","OPER COMPUTER SYS"

140,"MAINT ","MAINT SOFTWARE SYS"

150,"ADMSYS","ADM OPERATING SYS"

160,"ADMDB ","ADM DATA BASES"

170,"ADMDC ","ADM DATA COMM"

180,"DOC   ","DOCUMENT"

d.在命令行中输入sqlldr导入数据命令如下:

[oracle@NODE1 sqlldr]$ sqlldr scott/tiger control=./Act_load.ctl

SQL*Loader: Release 10.2.0.1.0 - Production on Sat Jan 1 22:55:08 2011

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

Commit point reached - logical record count 18

2.只有一个控制文件,控制文件中包含数据。

a.创建表

CREATE TABLE SCOTT.ACT_1

(

ACTNO    INTEGER                              NOT NULL,

ACTKWD   VARCHAR2(10 BYTE)                    NOT NULL,

ACTDESC  VARCHAR2(30 BYTE)                    NOT NULL,

ACTTIME  TIMESTAMP(6)

);

b.控制文件Act_Load1.ctl代码如下:

LOAD DATA

INFILE *     ------数据文件在一起,用*表示

TRUNCATE  ----操作类型,TRUNCATE清除表中原有记录(操作类型还可以为:INSERT/APPEND/REPLACE)

INTO TABLE ACT  ----插入记录表

FIELDS TERMINATED BY ',' ----数据中每列记录用','分隔(还可以用其他符号进行分隔)

OPTIONALLY ENCLOSED BY '"' -------数据中字段用' " '框起

TRAILING NULLCOLS --------表中的字段没有对应值允许插入空值

(ACTNO ,

ACTKWD ,

ACTDESC,

ACTTIME "LOCALTIMESTAMP"   -----------插入localtimestamp

)BEGINDATA

10,"MANAGE","MANAGE/ADVISE"

20,"ECOST ","ESTIMATE COST"

30,"DEFINE","DEFINE SPECS"

40,"LEADPR","LEAD PROGRAM/DESIGN"

50,"SPECS ","WRITE SPECS"

60,"LOGIC ","DESCRIBE LOGIC"

70,"CODE  ","CODE PROGRAMS"

80,"TEST  ","TEST PROGRAMS"

90,"ADMQS ","ADM QUERY SYSTEM"

100,"TEACH ","TEACH CLASSES"

110,"COURSE","DEVELOP COURSES"

120,"STAFF ","PERS AND STAFFING"

130,"OPERAT","OPER COMPUTER SYS"

140,"MAINT ","MAINT SOFTWARE SYS"

150,"ADMSYS","ADM OPERATING SYS"

160,"ADMDB ","ADM DATA BASES"

170,"ADMDC ","ADM DATA COMM"

180,"DOC   ","DOCUMENT"

c.在命令行中输入sqlldr导入数据命令如下:

[oracle@NODE1 sqlldr]$ sqlldr scott/tiger control=./Act_load1.ctl

SQL*Loader: Release 10.2.0.1.0 - Production on Sat Jan 1 23:08:05 2011

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

Commit point reached - logical record count 18

[oracle@NODE1 sqlldr]$

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL*LoaderOracle数据库的一个数据导入工具,可以将数据从外部文件导入到数据库表。它使用控制文件来指定数据加载的格式和规则。 以下是SQL*Loader使用步骤: 1. 创建控制文件 首先,你需要创建一个控制文件,它描述了数据文件的格式和如何加载数据。控制文件是一个文本文件,可以使用任何文本编辑器创建。以下是一个示例: ```sql LOAD DATA INFILE 'data.txt' INTO TABLE employees FIELDS TERMINATED BY ',' ENCLOSED BY '"' (employee_id, first_name, last_name) ``` 在上面的示例,控制文件指定了数据文件的名称('data.txt')和要将数据加载到的表(employees)。它还指定了字段的分隔符(逗号)和字段的封闭符号(引号)。最后,它列出了要加载的字段(employee_id、first_name和last_name)。 2. 准备数据文件 接下来,你需要准备一个包含要导入的数据的文本文件。确保数据文件的格式与控制文件指定的格式匹配。 3. 运行SQL*Loader 使用以下命令来运行SQL*Loader: ```bash sqlldr username/password@database control=control_file.ctl ``` 将`username`和`password`替换为你的Oracle数据库的用户名和密码,将`database`替换为你要连接的数据库名,将`control_file.ctl`替换为你创建的控制文件的路径。 运行后,SQL*Loader将开始加载数据文件的数据到指定的数据库表。 以上就是使用SQL*Loader导入数据的基本步骤。你可以根据自己的需求调整控制文件的参数和选项。更多关于SQL*Loader的详细信息,可以参考Oracle官方文档。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值