如果是txt文件的数据导入oracle中,数据量大的话用pl/sql会卡死,那么就要用到sqlload命令
首先需要将建立ctl格式的文件:
load data
infile 'D:\rh2015_2.txt'
append into table jg_hum
fields terminated by '|'
OPTIONALLY ENCLOSED BY '"'
TRAILING NULLCOLS
(
rh,
stid,
FRCSTDATE date "yyyy-mm-dd",
FRCSTHOUR,
LON,
LAT
)
*.ctl格式为:
load data
infile "d://test.txt"
infile "d://test1.txt"
append into table test
fields terminated by ","
OPTIONALLY ENCLOSED BY '"'
trailing nullcols
(
id integer external,
name "upper(:name)",
con ":id||:name",
dt date"yyyy-mm-dd"
)
说明:
load data
告诉SQLLDR要做什么(在这个例子中,则指示要加载数据)。SQLLDR还可以执行CONTINUE_LOAD,也就是继续加载。只有在继续一个多表直接路径加载时才能使用后面这个选项
INFILE * :如果是*号,这会告诉SQLLDR所要加载的数据实际上包含在控制文件本身上,例见下一文。如上例指定包含数据的另一个文件的文件名。如果愿意,可以使用一个命令行参数覆盖这个INFILE语句。要当心,命令行选项总会涵盖控制文件设置
在append的位置还可以用以下列表中的一个值:
insert
replace delete表中的数据,然后插入新值,记录多时速度慢
append
truncate trunctate表,然后插入新值,不能回退
FIELDS TERMINATED BY ‘,’:告诉SQLLDR数据的形式应该是用逗号分隔的值。为SQLLDR描述输入数据的方式有数十种;这只是其中较为常用的方法之一。
(id integer external,
.....
dt date"yyyy-mm-dd"):告诉SQLLDR所要加载的列、这些列在输入数据中的顺序以及数据类型。这是指输入流中数据的数据类型,而不是数据库中的数据类型。列的数据类型默认为CHAR(255)
在cmd命令下,执行
sqlldr userid=test/test@106.37.200.200/test control=d:/sql2.ctl log=d:/sqlldr2.log