当前位置:  数据库>oracle

Oracle 使用 Sql Loader加载数据

    来源: 互联网  发布时间:2017-04-19

    本文导语: 一、Oracle 数据库中,我们通常在不同数据库的表间记录进行复制或迁移时会用以下几种方法: 1、A 表的记录导出为一条条分号隔开的 insert 语句,然后执行插入到 B 表中。 2、建立数据库间的 dblink,然后用 create table B as select * f...

一、Oracle 数据库中,我们通常在不同数据库的表间记录进行复制迁移时会用以下几种方法

1、A 表的记录导出为一条条分号隔开的 insert 语句,然后执行插入到 B 表中。

2、建立数据库间的 dblink,然后用 create table B as select * from A@dblink where ...,或 insert into B select * from A@dblink where …。

3、exp A 表,再 imp 到 B 表,exp 时可加查询条件。

4、程序实现 select from A ..,然后 insert into B ...,也要分批提交。

5、Sql Loader(sqlldr) 来导入数据效果比起逐条 insert 来很明显。

二、在命令行下执行 Oracle 的 sqlldr 命令,可以看到它的详细参数说明

Username -- Oracle数据库名 。

Password -- Oracle数据库密码

Servicename -- 是Oracle服务实例名  。

Control -- 控制文件,可能包含表的数据

Log -- 记录导入时的日志文件,默认为 控制文件(去除扩展名).log。

Bad -- 坏数据文件,默认为 控制文件(去除扩展名).bad。

模板 iis7站长之家 -- 数据文件,一般在控制文件中指定。用参数控制文件中不指定数据文件更适于自动操作。

Errors -- 允许的错误记录数,可以用他来控制一条记录都不能错。

Rows -- 多少条记录提交一次,默认为 64。

Skip -- 跳过的行数,比如导出的数据文件前面几行是表头或其他描述。

Insert -- 为缺省方式,在数据装载开始时要求表为空

Append -- 在表中追加新记录

Replace -- 删除旧记录(用 delete from table 语句),替换成新装载的记录

Truncate -- 删除旧记录(用 truncate table 语句),替换成新装载的记录

OPTIONS (skip=1,rows=128) -- sqlldr 命令显示的选项可以写到这里边来,skip=1 用来跳过数据中的第一行,每128行提交一次

Fields terminated by "," -- 字段间隔为“,”

Optionally enclosed by '"' – 行记录间隔

Trailing nullcols -- 表的字段没有对应的值时允许为空

三、sqlldr 的使用,有两种使用方法:

1、只使用一个控制文件,在这个控制文件中包含数据。

2、使用一个控制文件(作为模板) 和一个数据文件。

一般为了利于模板和数据的分离,以及程序的不同分工会使用第二种方式。

四、举例:

此处使用第二种方法

建表file_list

create table file_list

(

  file_id  number,

  file_name  varchar2(250),

  created_date  date

) ;

创建数据文件file_list.data

15968600^025_value_added_0_201011301014_030937.Tdat^2010-11-30 10:18:20

15968572^025_call_0_201011301012_030907.Tdat^2010-11-30 10:16:16

15968596^025_data_0_201011301015_030964.Tdat^2010-11-30 10:17:53

创建控制文件file_list.ctl

OPTIONS (ROWS=1000)                                                                                                                                                             

load data                                                                                                                                                                       

infile 'E: file_list.dat'                                                                                                                                   

BADFILE 'E:logerror.bad'                                                                                                                                                          

replace into table file_list                                                                                                                                            

fields terminated by '^'                                                                                                                                                        

trailing nullcols                                                                                                                                                    

(

       FILE_ID

   ,FILE_NAME

   ,CREATED_DATE DATE "YYYY-MM-DD HH24:MI:SS"

)

五、运行:

点击开始->运行 键入cmd

执行以下命令:

E:>sqlldr username/password@servicename control=file_list.ctl


    
 
 

您可能感兴趣的文章:

  • 安装Oracle加载数据库错误areasQueries的解决
  • 如何将Oracle数据库驱动程序加载到classpath中?
  • Oracle数据库无法加载_OraMTS_的解决方法
  • Oracle 高速批量数据加载工具sql*loader使用说明
  • Oracle索引聚簇表的数据加载
  • linux下安装oracle后使用命令行启动的方法 linux启动oracle
  • Oracle9i 9.0.1的JDBC Drivers 可以给Oracle 8.0.5使用马?
  • Suse linux使用oracle问题
  • 请问:在使用oracle数据库作开发时,是使用pro*c作开发好些,还是使用库函数如oci等好一些啊?或者它们有什么区别或者优缺点啊?
  • jbuilder中使用oracle的问题
  • 求redhat linux 9.0下可以使用的oracle 10g或9i,还有redhat linux 9.0下可以使用的eclipse下载地址
  • Oracle事务!使用游标提交过程
  • 在Jbuilder7下,使用DbPilot.exe连接oracle,报错!请教高手!
  • AIX 64位系统上如何使用32位OCI oracle driver
  • Oracle中SQL语句连接字符串的符号使用介绍
  • 使用X manager连接oracle数据库的步骤
  • C++使用OCCI连Oracle10g的错误
  • 使用工具 plsqldev将Excel导入Oracle数据库
  • Linux下Oracle的sqlplus使用光标上下左右方法
  • Oracle 数据 使用游标
  • oracle使用sql脚本生成csv文件案例学习
  • ORACLE 修改表结构 之ALTER CONSTAINTS的使用
  • Linux中Oracle使用相关知识集锦
  • Oracle密码文件的使用和维护第1/3页
  • Oracle 触发器的使用小结
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • oracle数据库导出和oracle导入数据的二种方法(oracle导入导出数据)
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • ORACLE数据库常用字段数据类型介绍
  • 怎样调出ORACLE数据库中的数据,该如何连接?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • 用JDBC连接Oracle数据库时,如何向数据库中写日期型数据(格式)?谢了!
  • 关于JDBC连接Oracle数据库,是否必须有Oracle客户端
  • linux上安装oracle 数据库后,是否能写shell程序实现数据库的自动启动。
  • win2000+jbuilder6+oracle817编出的程序,在win2000下执行很好,在win98下却访问不了oracle数据库
  • jsp文件上传smartupload到oracle数据库中没有longblob的数据类型如何处理的?
  • 将Oracle 8i数据成功移植Oracle 10g的方法
  • Oracle收购TimesTen 提高数据库软件性能
  • 我从JSP页将数据插入到oracle数据库中,为何汉字插入后数据库中显示为乱码呢?
  • Oracle数据库恢复后心得
  • 紧急求救:对Oracle数据库中long 型数据进行模糊查询 如何查?
  • Linux下Oracle数据库,dbstart持续不动,数据库无法启动解决
  • 卸载oracle数据库
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle 10g和Oracle 11g网格技术介绍
  • Oracle EBS R12 支持 Oracle Database 11g
  • ORACLE日期相关操作
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3