Oracle sqlloader


sqlldr userid=scott/tiger direct=y control=d:\book1.ctl


SQL> create table sqlload_test(id number(2),
                               name varchar2(10));

--book1.ctl
load data
infile 'book1.csv'
into table sqlload_test
fields terminated by ','
(id ,
 name
)


--ldtest.ctl

load data
infile *
into table loader_test
replace
fields terminated by ','
(id,
 dt date 'dd/mm/yyyy',
 data "upper(:data)"
)
begindata
1,21/6/1999,hello
2,5/1/2000,oracle
3,15/3/2001,java


--加载固定格式数据 position

load data
infile *
into table dept
repalce
( deptno position(1:2),
  dname  position(3:16),
  loc    position(17:29)
)
begindata
10Accounting    Virginia,usa


可以用*代替数字,表示下一位置。也可以重复使用位置。

load data
infile *
into table dept
repalce
( deptno      position(1:2),
  dname       position(*:16),
  loc         position(*:29),
  entire_line position(1:29)
)
begindata
10Accounting    Virginia,usa


--加载日期字段
dt date 'dd/mm/yyyy'


--加载带有函数的字段

name "upper(:name)"


--加载内嵌换行符的字段

参考《9i-10g-11g编程艺术》 sqlloader章节


--加载LOB数据

参考《9i-10g-11g编程艺术》 sqlloader章节

 

--注意
(into)
其中append为数据装载方式,还有其他选项:  
a、insert,为缺省方式,在数据装载开始时要求表为空  
b、append,在表中追加新记录  
c、replace,删除旧记录,替换成新装载的记录  
d、truncate,同上

sqlloader默认使用字符长度char(255),如果字符字段长度超过255会报错,加大字符长度即可

fields terminated by ',' optionally enclosed by '"'
蓝色部分允许在字符中使用引号,如 ""USA""


--使用参数文件装载数据
sqlldr parfile=/u01/load.par

load.par为参数文件:
userid=ikki/ikki
control='/u01/loadtest.ctl'
data='/u01/loadtest.csv'
log='/u01/loadtest.log'
direct=true
unrecoverable=true  --不需要在重做日志文件中记录新装载的数据

 

请使用浏览器的分享功能分享到微信等