oracle装载表即通过sqlloader的方式导入数据。
  Oracle 的SQL*LOADER可以将外部数据加载到数据库表中。下面是SQL*LOADER的基本特点:
  1)能装入不同数据类型文件及多个数据文件的数据
  2)可装入固定格式,自由定界以及可度长格式的数据
  3)可以装入二进制,压缩十进制数据
  4)一次可对多个表装入数据
  5)连接多个物理记录装到一个记录中
  6)对一单记录分解再装入到表中
  7)可以用 数对制定列生成唯一的KEY
  8)可对磁盘或 磁带数据文件装入制表中
  9)提供装入错误报告
  10)可以将文件中的整型字符串,自动转成压缩十进制并装入列表中。
  1.2控制文件
  控制文件是用一种语言写的文本文件,这个文本文件能被SQL*LOADER识别。SQL*LOADER根据控制文件可以找到需要加载的数据。并且分析和解释这些数据。控制文件由三个部分组成:
  l 全局选件,行,跳过的记录数等;
  l INFILE子句指定的输入数据;
  l 数据特性说明。
  1.3输入文件
  对于 SQL*Loader, 除控制文件外就是输入数据。SQL*Loader可从一个或多个指定的文件中读出数据。如果数据是在控制文件中指定,就要在控制文件中写成 INFILE * 格式。当数据固定的格式(长度一样)时且是在文件中得到时,要用INFILE "fix n"
  load data
  infile 'example.dat' "fix 11"
  into table example
  fields terminated by ',' optionally enclosed by '"'
  (col1 char(5),
  col2 char(7))
  example.dat:
  001, cd, 0002,fghi,
  00003,lmn,
  1, "pqrs",
  0005,uvwx,
  当数据是可变格式(长度不一样)时且是在文件中得到时,要用INFILE "var n"。如:
  load data
  infile 'example.dat' "var 3"
  into table example
  fields terminated by ',' optionally enclosed by '"'
  (col1 char(5),
  col2 char(7))
  example.dat:
  009hello,cd,010world,im,
  012my,name is,
  1.4坏文件
  坏文件包含那些被SQL*Loader拒绝的记录。被拒绝的记录可能是不符合要求的记录。
  坏文件的名字由 SQL*Loader命令的BADFILE 参数来给定。
  1.5日志文件及日志信息
  当SQL*Loader 开始执行后,它就自动建立 日志文件。日志文件包含有加载的总结,加载中的错误信息等。
  控制文件语法
  控制文件的格式如下:
  OPTIONS ( { [SKIP=integer] [ LOAD = integer ]
  [ERRORS = integer] [ROWS=integer]
  [BINDSIZE=integer] [SILENT=(ALL|FEEDBACK|ERROR|DISCARD) ] )
  LOAD[DATA]
  [ { INFILE | INDDN } {file | * }
  [STREAM | RECORD | FIXED length [BLOCKSIZE size]|
  VARIABLE [length] ]
  [ { BADFILE | BADDN } file ]
  {DISCARDS | DISCARDMAX} integr ]
  [ {INDDN | INFILE} . . . ]
  [ APPEND | REPLACE | INSERT ]
  [RECLENT integer]
  [ { CONCATENATE integer |
  CONTINUEIF { [THIS | NEXT] (start[: end])LAST }
  Operator { 'string' | X 'hex' } } ]
  INTO TABLE [user.]table
  [APPEND | REPLACE|INSERT]
  [WHEN condition [AND condition]...]
  [FIELDS [delimiter] ]
  (
  column {
  RECNUM | CONSTANT value |
  SEQUENCE ( { integer | MAX |COUNT} [, increment] ) |
  [POSITION ( { start [end] | * [ + integer] }
  ) ]
  datatype
  [TERMINATED [ BY ] {WHITESPACE| [X] 'character' } ]
  [ [OPTIONALLY] ENCLOSE[BY] [X]'charcter']
  [NULLIF condition ]
  [DEFAULTIF condotion]
  }
  [ ,...]
  )
  [INTO TABLE...]
  [BEGINDATA]
  1)要加载的数据文件:
  1.INFILE 和INDDN是同义词,它们后面都是要加载的数据文件。如果用 * 则表示数据就在控制文件内。在INFILE 后可以跟几个文件。
  2.STRAM 表示一次读一个字节的数据。新行代表新物理记录(逻辑记录可由几个物理记录组成)。
  3.RECORD 使用宿主操作系统文件及记录管理系统。如果数据在控制文件中则使用这种方法。
  3. FIXED length 要读的记录长度为length字节,
  4. VARIABLE 被读的记录中前两个字节包含的长度,length 记录可能的长度。缺伤为8k字节。
  5. BADFILE和BADDN同义。Oracle 不能加载数据到数据库的那些记录。
  6. DISCARDFILE和DISCARDDN是同义词。记录没有通过的数据。
  7. DISCARDS和DISCARDMAX是同义词。Integer 为最大放弃的文件个数。
  2)加载的方法:
  1.APPEND 给表添加行。
  2.INSERT 给空表增加行(如果表中有记录则退出)。
  3.REPLACE 先清空表在加载数据。
  4. RECLEN 用于两种情况,1)SQLLDR不能自动计算记录长度,2)或用户想看坏文件的完整记录时。对于后一种,Oracle只能按常规把坏记录部分写到错误的地方。如果看整条记录,则可以将整条记录写到坏文件中。
  3)指定最大的记录长度:
  1. CONCATENATE 允许用户设定一个整数,表示要组合逻辑记录的数目。
  4)建立逻辑记录:
  1.THIS 检查当前记录条件,如果为真则连接下一个记录。
  2.NEXT 检查下一个记录条件。如果为真,则连接下一个记录到当前记录来。
  2. Start: end 表示要检查在THIS或NEXT字串是否存在继续串的列,以确定是否进行连接。如:continueif next(1-3)='WAG' 或continueif next(1-3)=X'0d03if'
  5)指定要加载的表:
  1.INTO TABLE 要加的表名。
  2.WHEN 和select WHERE类似。用来检查记录的情况,如:when(3-5)='SSM' and (22)='*"
  6)介绍并括起记录中的字段:
  1. FIELDS给出记录中字段的分隔符,FIELDS格式为:
  FIELDS [TERMIALED [BY] {WHITESPACE | [X] 'charcter'} ]
  [ [ OPTIONALLY] ENCLOSE [BY] [X]'charcter' ]
  TERMINATED 读完前一个字段即开始读下一个字段直到介绍。
  WHITESPACE 是指结束符是空格的意思。包括空格、Tab、换行符、换页符及回车符。如果是要判断但字符,可以用单引号括起,如X'1B'等。
  OPTIONALLY ENCLOSED 表示数据应由特殊字符括起来。也可以括在TERMINATED字符内。使用OPTIONALLY要同时用TERMINLATED。
  ENCLOSED 指两个分界符内的数据。如果同时用 ENCLOSED和TERMINAED ,则它们的顺序决定计算的顺序。
  7)定义列:
  column 是表列名。列的取值可以是:
  BECHUM 表示逻辑记录数。第一个记录为1,第2个记录为2。
  CONSTANT 表示赋予常数。
  SEQUENCE 表示序列可以从任意序号开始,格式为:
  SEQUENCE ( { integer | MAX |COUNT} [,increment]
  POSITION 给出列在逻辑记录中的位置。可以是绝对的,或相对前一列的值。格式为:
  POSITION ( {start[end] | * [+integer] } )
  Start 开始位置
  * 表示前字段之后立刻开始。
  + 从前列开始向后条的位置数。
  8)定义数据类型:
  可以定义14种数据类型:
  CHAR
  DATE
  DECIMAL EXTERNAL
  DECIMAL
  DOUBLE
  FLOAT
  FLOAT EXTERNAL
  GRAPHIC EXTERNAL
  INTEGER
  INTEGER EXTERNAL
  SMALLINT
  VARCHAR
  VARGRAPHIC
  1.字符类型数据
  CHAR[ (length)] [delimiter]
  length缺省为 1.
  2.日期类型数据
  DATE [ ( length)]['date_format' [delimiter]
  使用to_date函数来限制。
  3.字符格式中的十进制
  DECIMAL EXTERNAL [(length)] [delimiter]
  用于常规格式的十进制数(不是二进制=> 一个位等于一个bit)。
  4.压缩十进制格式数据
  DECIMAL (digtial [,divcision])
  5.双精度符点二进制
  DOUBLE
  6.普通符点二进制
  FLOAT
  7.字符格式符点数
  FLOAT EXTERNAL [ (length) ] [delimiter]
  8.双字节字符串数据
  GRAPHIC [ (legth)]
  9.双字节字符串数据
  GRAPHIC EXTERNAL[ (legth)]
  10.常规全字二进制整数
  INTEGER
  11.字符格式整数
  INTEGER EXTERNAL
  12.常规全字二进制数据
  SMALLINT
  13.可变长度字符串
  VARCHAR
  14.可变双字节字符串数据
  VARGRAPHIC
  2.2写控制文件CTL
  1. 各数据文件的文件名;
  2.各数据文件格式;
  3.各数据文件里各数据记录字段的属性;
  4.接受数据的ORACLE表列的属性;
  5.数据定义;
  6.其它
  数据文件的要求:
  数据类型的指定
  CHAR 字符型
  INTEGER EXTERNAL 整型
  DECIMAL EXTERNAL 浮点型
  3.1数据文件的内容
  可以在OS下的一个文件;或跟在控制文件下的具体数据。数据文件可以是:
  1、 二进制与字符格式:LOADER可以把二进制文件读(当成字符读)列表中
  2、 固定格式:记录中的数据、数据类型、 数据长度固定。
  3、 可变格式:每个记录至少有一个可变长数据字段,一个记录可以是一个连续的字符串。
  数据段的分界(如姓名、年龄)如用“,”作字段的 分 ;用,"’作数据
  括号等
  4、 LOADER可以使用多个连续字段的物理记录组成一个逻辑记录,记录文件运行情况文件:包括以下内容:
  1、 运行日期:软件版本号
  2、 全部输入,输出文件名;对命令行的展示信息,补充信息,
  3、 对每个装入信息报告:如表名,装入情况;对初始装入, 加截入或更新装
  入的选择情况,栏信息
  4、 数据错误报告:错误码;放弃记录报告
  5、 每个装X报告:装入行;装入行数,可能跳过行数;可能拒绝行数;可能放
  弃行数等
  6、 统计概要:使用空间(包大小,长度);读入记录数,装入记录数,跳过记
  录数;拒绝记录数,放弃记录数;运行时间等。
转自:oracle装载表是什么?

oracle装载表是什么?的更多相关文章

  1. ORACLE外部表总结

    外部表介绍 ORACLE外部表用来存取数据库以外的文本文件(Text File)或ORACLE专属格式文件.因此,建立外部表时不会产生段.区.数据块等存储结构,只有与表相关的定义放在数据字典中.外部表 ...

  2. Oracle外部表详解(转载)

    (外部表创建主要注意创建目录访问权限问题.目录路径格式无空格等不相关字符,即必须是当前表访问用户可以访问:关于表中行数的限制问题,如果不加限制注意添加reject limit unlimited:表中 ...

  3. Oracle外部表详解

    外部表概述 外部表只能在Oracle 9i之后来使用.简单地说,外部表,是指不存在于数据库中的表.通过向Oracle提供描述外部表的元数据,我们可以把一个操作系统文件当成一个只读的数据库表,就像这些数 ...

  4. Oracle的表锁死以及解锁

    Oracle的表锁死以及解锁 oracle 查看锁死的表,锁死的进程. select sess.sid, sess.serial#, lo.oracle_username, lo.os_user_na ...

  5. 如何利用Oracle外部表导入文本文件的数据

    同事最近在忙数据一致性比对工作,需要对不同文本文件中的数据进行比对,有的文件较大,记录较多,如果用普通的文本编辑器打开的话,很显然,会很卡,甚至打不开. 基于此,可将该文本文件的数据导入到数据库中,在 ...

  6. Oracle新表使用序列(sequence)作为插入值,初始值不是第一个,oraclesequence

    Oracle新表使用序列(sequence)作为插入值,初始值不是第一个,oraclesequence 使用oracle11g插入数据时遇到这样一个问题: 1 --创建测试表-- 2 CREATE T ...

  7. oracle 锁表问题

    oracle执行表数据更新的时候,会遇到锁表问题,比方说,会遇到这样的问题,主要原因是这张表被其他人占用,修改数据没有提交.oracle为了避免脏数据的产生,在其安全机制下,锁住该表. 执行如下操作, ...

  8. oracle数据库表空间追加数据库文件方法

    oracle数据库表空间追加数据库文件方法   针对非大文件方式表空间,允许追加文件进行表空间的扩展,单个文件最大大小是32G  第一种方式:表空间增加数据文件    www.2cto.com   1 ...

  9. oracle大表添加字段default经验分享

    当oracle单表数据量上亿时,对表进行alter table aa add column_1 varchar2(2) defalut 'Y';时,效率及安全性是必须考虑的因素. 本帖以2亿的数据表a ...

随机推荐

  1. 从事务隔离级别谈到Hibernate乐观锁,悲观锁

    数据库的事务,是指作为单个逻辑工作单元执行的一系列操作. 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源.通过将一组相关操作组合为一个要么全部成功要么全部失败的单 ...

  2. python-minidom模块【解析xml】

    1,xml的文档结构 1.1,XML文档包括XML头信息和XML信息体 1.1.1,XML文档头信息 <?xml version="1.0" encoding="u ...

  3. Maven 统一指定jar包版本的方法

    在看别人的源码的过程中,会遇到这种情况,就是很多jar包没有指定版本,却能够下载下来. 在后来的研究中发现,有这样一个配置. <parent> <groupId>org.spr ...

  4. 【卡西欧Fx-5800p系列教程】Pol()和Rec()正反算妙用

    一.背景概述 我要单独把这两个公式列出来写篇文章, 我觉得搞测量的如果能熟练运用 Pol()和Rec()这两个公式,那么他是会用卡西欧计算器的里程碑事件,也就是说,你开始入门了. 为什么呢?他虽然是内 ...

  5. codeigniter2.2.5连接mssql2008Rc2

    一.环境:php5.2.17(nts)+apache(Apache/2.2.22 (Win32))+server 2008 二.php框架:codeigniter2.2.5 三.配置php.ini # ...

  6. Jackson学习笔记(三)<转>

    概述 使用jackson annotations简化和增强的json解析与生成. Jackson-2.x通用annotations列表:https://github.com/FasterXML/jac ...

  7. Go Revel - server.go 源码分析

    之前介绍了 Go Revel - main函数分析 http://www.cnblogs.com/hangxin1940/p/3263775.html 最后会调用 `revel.Run(*port)` ...

  8. C#获取MySql 数据常用的代码

    1.读取 public DataTable ExecuteDataTable(string SQLString) { using (MySqlConnection connection = new M ...

  9. fiddler手机端抓包

    1. 买个360随身wifi,插在台式机上生成热点,手机连上自己的wifi 如果电脑与手机本就在一个局域网,省略这一步 2. 在fiddler中如下设置: 3. 查看电脑无线连接属性 4. 在手机上设 ...

  10. PHP中“==”运算符的安全问题

    前言 PHP是一种通用的开源脚本语言,它的语法混合了C,Java,以及Perl等优秀语言的语法.除此之外,它还提供了大量的函数库可供开发人员使用.但是,如果使用不当,PHP也会给应用程序带来非常大的安 ...