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 --不需要在重做日志文件中记录新装载的数据
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/27633655/viewspace-1081523/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/27633655/viewspace-1081523/