sql load的初体验(一)

2014-11-24 13:18:26 · 作者: · 浏览: 0

今天第一次使用oracle的sql toad,感觉挺好的,我们在使用imp或是impdp的时候可以备份,恢复维护我们的数据库,尽管她在不同版本之前有version这个参数(在小版本之间可以来回迁移,在大的版本之间尚未测试),还是感觉不是太好的;如果想在不同版本之间的做迁移我们可以使用oracle load它可以把一些以文本格式存放的数据顺利的导入到oracle数据库中,是一种在不同数据库之间进行数据迁移的非常方便而且通用的工具。缺点就速度比较慢,另外对blob等类型的数据就有点麻烦了。

oracle自己带了很多的工具可以用来进行数据的迁移、备份和恢复等工作。但是每个工具都有自己的特点。比如说exp和imp可以对数据库中的数据进行导出和导出的工作,是一种很好的数据库备份和恢复的工具,因此主要用在数据库的热备份和恢复方面。有着速度快,使用简单,快捷的优点;同时也有一些缺点,比如在不同版本数据库之间的导出、导入的过程之中,总会出现这样或者那样的问题,这个也许是oracle公司自己产品的兼容性的问题吧。

我们可以在dos下面或是linus上面查看sqlldr的帮助:

在dos下面直接执行sqlldr就可以查看:

C:\>sqlldr

SQL*Loader: Release 10.2.0.3.0 - Production on 星期五12月16 11:29:08 2011

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

用法: SQLLDR keyword=value [,keyword=value,...]

有效的关键字:

userid -- ORACLE 用户名/口令

control -- 控制文件名

log -- 日志文件名

bad -- 错误文件名

data -- 数据文件名

discard -- 废弃文件名

discardmax -- 允许废弃的文件的数目 (全部默认)

skip -- 要跳过的逻辑记录的数目 (默认0)

load -- 要加载的逻辑记录的数目 (全部默认)

errors -- 允许的错误的数目 (默认50)

rows -- 常规路径绑定数组中或直接路径保存数据间的行数

(默认: 常规路径64, 所有直接路径)

bindsize -- 常规路径绑定数组的大小(以字节计) (默认256000)

silent -- 运行过程中隐藏消息(标题,反馈,错误,废弃,分区)

direct -- 使用直接路径 (默认FALSE)

parfile -- 参数文件: 包含参数说明的文件的名称

parallel -- 执行并行加载 (默认FALSE)

file -- 要从以下对象中分配区的文件

skip_unusable_indexes -- 不允许/允许使用无用的索引或索引分区 (默认FALSE)

skip_index_maintenance -- 没有维护索引, 将受到影响的索引标记为无用 (默认FALSE)

commit_discontinued -- 提交加载中断时已加载的行 (默认FALSE)

readsize -- 读取缓冲区的大小 (默认1048576)

external_table -- 使用外部表进行加载; NOT_USED, GENERATE_ONLY, EXECUTE (默认NOT_USED)

columnarrayrows -- 直接路径列数组的行数 (默认5000)

streamsize -- 直接路径流缓冲区的大小(以字节计) (默认256000)

multithreading -- 在直接路径中使用多线程

resumable -- 启用或禁用当前的可恢复会话 (默认FALSE)

resumable_name -- 有助于标识可恢复语句的文本字符串

resumable_timeout -- RESUMABLE 的等待时间(以秒计) (默认7200)

date_cache -- 日期转换高速缓存的大小(以条目计) (默认1000)

PLEASE NOTE: 命令行参数可以由位置或关键字指定

。前者的例子是'sqlload

scott/tiger foo'; 后一种情况的一个示例是'sqlldr control=foo

userid=scott/tiger'.位置指定参数的时间必须早于

但不可迟于由关键字指定的参数。例如,

允许'sqlldr scott/tiger control=foo logfile=log', 但是

不允许'sqlldr scott/tiger control=foo log', 即使

参数'log' 的位置正确。

C:\>

在使用sqlldr的时候使用到的文件包括:

数据文件Data File:数据源[文本文件]

控制文件Control File:导入数据规则此控制文件非彼控制文件,是定义导如的规则!

日志文件Log File:导入数据记录情况

坏文件Bad File:插入记录出错,如违反唯一约束,非空约束...

卡片文件Discard File:没有被选择的记录

依次是我们要导入的内容,我们执行的代码,我们导入的日志,在导入过程中出现的插入记录错误,没有被选择的记录(这个我还不太理解是没有插入的记录还是上面?)

t.txt

这个是我要插入的内容:

a,b,c

a,b,c

a,b,c

a,b,c

a,b,c

a,b,c

a,b,c

a,b,c

a,b,c

我们需要根据我们要插入的内容在数据库中创建相应的表,以便我可以插入内容

这是我的表结构 www.2cto.com

SQL> desc s

名称 是否为空 类型

----------------------------------------- -------- ----------------

S_I VARCHAR2(10)

S_E VARCHAR2(10)

S_N VARCHAR2(10)

t.ctl

这个是我的执行脚本

options (errors=-1)

load data

infile 'c:\t.txt'

badfile 'c:\error.bad'

discardfile 'c:\discard.txt'

truncate into table s --这里有几个参数分别是insert ,