sql loader可以把一些以文本格式存放的数据顺利的导入到oracle数据库中,是一种在不同数据库之间进行数据迁移的非常方便而且通用的工具。缺点就速度比较慢,另外对blob等类型的数据就有点麻烦了。
用法: SQLLDR keyword=value [,keyword=value,...]
在命令行下执行 Oracle 的 sqlldr 命令,可以看到它的详细参数说明,要着重关注以下几个参数:
userid -- Oracle 的 username/password[@servicename]
control -- 控制文件,可能包含表的数据
-------------------------------------------------------------------------------------------------
log -- 记录导入时的日志文件,默认为 控制文件(去除扩展名).log
bad -- 坏数据文件,默认为 控制文件(去除扩展名).bad
data -- 数据文件,一般在控制文件中指定。用参数控制文件中不指定数据文件更适于自动操作
errors -- 允许的错误记录数,可以用他来控制一条记录都不能错
rows -- 多少条记录提交一次,默认为 64
skip -- 跳过的行数,比如导出的数据文件前面几行是表头或其他描述
还有更多的 sqlldr 的参数说明请参考:sql loader的用法。
用例子来演示 sqlldr 的使用,有两种使用方法:
1. 只使用一个控制文件,在这个控制文件中包含数据
2. 使用一个控制文件(作为模板) 和一个数据文件
下面来看示例
- create table users(
- user_id number, --用户 ID
- user_name varchar2(50), --用户名
- login_times number, --登陆次数
- last_login date --最后登录日期
- )
- insert into users values (1, 'Unmi' ,3,sysdate);
- insert into users values (2, NULL ,5,to_date( '2008-10-15' , 'YYYY-MM-DD' ));
- insert into users values (3, '隔叶黄莺' ,8,to_date( '2009-01-02' , 'YYYY-MM-DD' ));
- insert into users values (5, '不知秋' ,1,to_date( '2008-12-23' , 'YYYY-MM-DD' ));
- OPTIONS (skip= 1 ,rows= 128 ) -- sqlldr 命令显示的选项可以写到这里边来,skip= 1 用来跳过数据中的第一行
- LOAD DATA
- INFILE "users_data.csv" --指定外部数据文件,可以写多个 INFILE "another_data_file.csv" 指定多个数据文件,也可以在此处不写,在后面指定
- --这里还可以使用 BADFILE、DISCARDFILE 来指定坏数据和丢弃数据的文件,
- truncate --操作类型,用 truncate table 来清除表中原有记录
- INTO TABLE users -- 要插入记录的表
- Fields terminated by "," -- 数据中每行记录用 "," 分隔
- Optionally enclosed by '"' -- 数据中每个字段用 '"' 框起,比如字段中有 "," 分隔符时
- trailing nullcols --表的字段没有对应的值时允许为空
- (
- virtual_column FILLER, --这是一个虚拟字段,用来跳过由 PL/SQL Developer 生成的第一列序号
- user_id number, --字段可以指定类型,否则认为是 CHARACTER 类型, log 文件中有显示
- user_name,
- login_times,
- last_login DATE "YYYY-MM-DD HH24:MI:SS" -- 指定接受日期的格式,相当用 to_date() 函数转换
- )
- 说明:在操作类型 truncate 位置可用以下中的一值:
- 1 ) insert --为缺省方式,在数据装载开始时要求表为空
- 2 ) append --在表中追加新记录
- 3 ) replace --删除旧记录(用 delete from table 语句),替换成新装载的记录
- 4 ) truncate --删除旧记录(用 truncate table 语句),替换成新装载的记录
执行命令
- sqlldr userid=scott/anwei@orcl control=user.ctl data=user.cvs log=user.log
执行完 sqlldr 后希望能留意一下生成的几个文件,如 users.log 日志文件、users.bad 坏数据文件等。特别是要看看日志文件,从中可让你更好的理解 Sql Loader,里面有对控制文件的解析、列出每个字段的类型、加载记录的统计、出错原因等信息。