当前位置:  数据库>oracle

Oracle sqlload加载数据

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

    本文导语: 一、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。

Data -- 数据文件,一般在控制文件中指定。用参数控制文件中不指定数据文件更适于自动操作。

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


    
 
 
 
本站(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