sqlldr的介绍
  SQL*LOADER是ORACLE的数据加载工具,通常用来将操作系统文件(数据)迁移到ORACLE数据库中。SQL*LOADER是大型数据仓库选择使用的加载方法,因为它提供了最快速的途径(DIRECT,PARALLEL)。

  sqlldr的执行(在UNIX下用shell来调用)
  $ORACLE_HOME/bin/sqlldr dwh/cognos@ORA8 control=../tmp/load.ctl
  $ORACLE_HOME/bin/sqlldr dwh/cognos@ORA8 control=../tmp/load.ctl direct=true log=...

  制定控制文件load.ctl
  1、控制文件标识
  2、要输入的数据文件名为test.txt
  3、向表test中(追加)记录
  4、指定分隔符
  load data
  infile '/query5/Ascential/data/month/mgmid.200304M'
  into table DC_RPT_T_MGMID_200304M_30 append(APPEND为追加方式,或REPLACE)
  fields terminated by ','
  (
    userid,
    svcnum,
    brand,
    svcPlan,
    busist,
    hvcFlag,
    mntFlag,
    userYear,
    joinMonth,
    callfee,
    callfeefav,
    tollfee,
    tollfeefav,
    calltimes,
    callduration,
    billduration,
    tollduration,
    totalFee,
    groupID
  )

  导入方式
  ************* 以下是4种装入表的方式
  APPEND // 原先的表有数据 就加在后面
  INSERT // 装载空表 如果原先的表有数据 sqlloader会停止 默认值
  REPLACE // 原先的表有数据 原先的数据会全部删除
  TRUNCATE // 指定的内容和replace的相同 会用truncate语句删除现存数据

  导入日期型字段
  LOAD DATA
  INFILE 'zlx.TXT'
  append INTO TABLE zlx
  FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
  (
    ID,
    L,
    F,
    M,
    DATE1 date 'dd-mm-yyyy'
  )

  SQLLoader将 Excel 数据导出到 Oracle
  1.创建SQL*Loader输入数据所需要的文件,均保存到C:,用记事本编辑控制文件:input.ctl,内容如下:
  load data           --1、控制文件标识
  infile 'test.txt'       --2、要输入的数据文件名为test.txt
  append into table test    --3、向表test中追加记录
  fields terminated by X'09'  --4、字段终止于X'09',是一个制表符(TAB)
  (id,username,password,sj)   -----定义列对应顺序

  2.还有一种方法
  可以把EXCEL文件另存为CSV(逗号分隔)(*.csv),控制文件就改为用逗号分隔
  LOAD DATA
  INFILE 'd:car.csv'
  APPEND INTO TABLE t_car_temp
  FIELDS TERMINATED BY ‘,’
  (phoneno,vip_car)

  在控制文件中直接导入数据
  1、控制文件test.ctl的内容
  LOAD DATA
  INFILE *
  BADFILE 'C:Documents and SettingsJackey桌面WMCOUNTRY.BAD'
  INSERT INTO TABLE EMCCOUNTRY
  Fields terminated by ‘;’ Optionally enclosed by '"'
  (
    COUNTRYID,
    COUNTRYCODE,
    COUNTRYNAME,
    CONTINENTID ,
    MAPID ,
    CREATETIME DATE ‘MM/DD/YYYY HH24:MI:SS’
    LASTMODIFIEDTIME DATE ‘MM/DD/YYYY HH24:MI:SS’
  )
  BEGINDATA
  1;"JP";"Japan";1;9;"09/16/2004 16:31:32";
  2;"CN";"China";1;10;"09/16/2004 16:31:32";
  3;"IN";"India";1;11;"09/16/2004 16:31:32";
  4;"AU";"Australia";6;12;"09/16/2004 16:31:32";
  5;"CA";"Canada";4;13;"09/16/2004 16:31:32";
  6;"US";"United States";4;14;"09/16/2004 16:31:32";
  7;"MX";"Mexico";4;15;"09/16/2004 16:31:32";
  8;"GB";"United Kingdom";3;16;"09/16/2004 16:31:32";
  9;"DE";"Germany";3;17;"09/16/2004 16:31:32";
  10;"FR";"France";3;18;"09/16/2004 16:31:32";
  11;"IT";"Italy";3;19;"09/16/2004 16:31:32";
  12;"ES";"Spain";3;20;"09/16/2004 16:31:32";
  13;"FI";"Finland";3;21;"09/16/2004 16:31:32";
  14;"SE";"Sweden";3;22;"09/16/2004 16:31:32";
  15;"IE";"Ireland";3;23;"09/16/2004 16:31:32";
  16;"NL";"Netherlands";3;24;"09/16/2004 16:31:32";
  17;"DK";"Denmark";3;25;"09/16/2004 16:31:32";
  18;"BR";"Brazil";5;85;"09/30/2004 11:25:43";
  19;"KR";"Korea, Republic of";1;88;"09/30/2004 11:25:43";
  20;"NZ";"New Zealand";6;89;"09/30/2004 11:25:43";
  21;"BE";"Belgium";3;79;"09/30/2004 11:25:43";
  22;"AT";"Austria";3;78;"09/30/2004 11:25:43";
  23;"NO";"Norway";3;82;"09/30/2004 11:25:43";
  24;"LU";"Luxembourg";3;81;"09/30/2004 11:25:43";
  25;"PT";"Portugal";3;83;"09/30/2004 11:25:43";
  26;"GR";"Greece";3;80;"09/30/2004 11:25:43";
  27;"IL";"Israel";1;86;"09/30/2004 11:25:43";
  28;"CH";"Switzerland";3;84;"09/30/2004 11:25:43";
  29;"A1";"Anonymous Proxy";0;0;"09/30/2004 11:25:43";
  30;"A2";"Satellite Provider";0;0;"09/30/2004 11:25:43";
  31;"AD";"Andorra";3;0;"09/30/2004 11:25:43";
  32;"AE";"United Arab Emirates";1;0;"09/30/2004 11:25:43";
  33;"AF";"Afghanistan";1;0;"09/30/2004 11:25:43";
  34;"AG";"Antigua and Barbuda";7;0;"09/30/2004 11:25:43";
  35;"AI";"Anguilla";7;0;"09/30/2004 11:25:43";
  36;"AL";"Albania";3;0;"09/30/2004 11:25:43";
  37;"AM";"Armenia";3;0;"09/30/2004 11:25:43";
  38;"AN";"Netherlands Antilles";3;0;"09/30/2004 11:25:43";
  39;"AO";"Angola";2;0;"09/30/2004 11:25:43";
  40;"AP";"Asia/Pacific Region";2;0;"09/30/2004 11:25:43";
  41;"AQ";"Antarctica";8;0;"09/30/2004 11:25:43";
  42;"AR";"Argentina";5;0;"09/30/2004 11:25:43";
  43;"AS";"American Samoa";6;0;"09/30/2004 11:25:43";
  44;"AW";"Aruba";5;0;"09/30/2004 11:25:43";
  45;"AZ";"Azerbaijan";1;0;"09/30/2004 11:25:43";
  46;"BA";"Bosnia and Herzegovina";3;0;"09/30/2004 11:25:43";
  47;"BB";"Barbados";5;0;"09/30/2004 11:25:43";
  48;"BD";"Bangladesh";1;0;"09/30/2004 11:25:43";
  49;"BF";"Burkina Faso";2;0;"09/30/2004 11:25:43";
  50;"BG";"Bulgaria";3;0;"09/30/2004 11:25:43";
  51;"BH";"Bahrain";1;0;"09/30/2004 11:25:43";
  52;"BI";"Burundi";2;0;"09/30/2004 11:25:43";
  53;"BJ";"Benin";2;0;"09/30/2004 11:25:43";
  54;"BM";"Bermuda";4;0;"09/30/2004 11:25:43";
  55;"BN";"Brunei Darussalam";1;0;"09/30/2004 11:25:43";
  56;"BO";"Bolivia";5;0;"09/30/2004 11:25:43";
  57;"BS";"Bahamas";7;0;"09/30/2004 11:25:43";
  58;"BT";"Bhutan";1;0;"09/30/2004 11:25:43";
  59;"BV";"Bouvet Island";5;0;"09/30/2004 11:25:43";
  60;"BW";"Botswana";2;0;"09/30/2004 11:25:43";
  61;"BY";"Belarus";3;0;"09/30/2004 11:25:43";
  2、执行导入命令
  C:>sqlldr userid=system/manager control=test.ctl

  有效的关键字:
  
userid -- ORACLE username/password
  control -- Control file name
  log -- Log file name
  bad -- Bad file name
  data -- Data file name
  discard -- Discard file name
  discardmax -- Number of discards to allow (全部默认)
  skip -- Number of logical records to skip (默认0)
  load -- Number of logical records to load (全部默认)
  errors -- Number of errors to allow (默认50)
  rows -- Number of rows in conventional path bind array or between direct path data saves(默认: 常规路径 64, 所有直接路径)
  bindsize -- Size of conventional path bind array in bytes(默认256000)
  silent -- Suppress messages during run (header,feedback,errors,discards,partitions)
  direct -- use direct path (默认FALSE)
  parfile -- parameter file: name of file that contains parameter specifications
  parallel -- do parallel load (默认FALSE)
  file -- File to allocate extents from
  skip_unusable_indexes -- disallow/allow unusable indexes or index partitions(默认FALSE)
  skip_index_maintenance -- do not maintain indexes, mark affected indexes as unusable(默认FALSE)
  readsize -- Size of Read buffer (默认1048576)
  external_table -- use external table for load; NOT_USED, GENERATE_ONLY, EXECUTE(默认NOT_USED)
  columnarrayrows -- Number of rows for direct path column array(默认5000)
  streamsize -- Size of direct path stream buffer in bytes(默认256000)
  multithreading -- use multithreading in direct path
  resumable -- enable or disable resumable for current session(默认FALSE)
  resumable_name -- text string to help identify resumable statement
  resumable_timeout -- wait time (in seconds) for RESUMABLE(默认7200)
  date_cache -- size (in entries) of date conversion cache(默认1000)

  PLEASE NOTE: 命令行参数可以由位置或关键字指定。前者的例子是 'sqlload scott/tiger foo'; 后一种情况的一个示例是 'sqlldr control=foouserid=scott/tiger'.位置指定参数的时间必须早于但不可迟于由关键字指定的参数。例如,允许 'sqlldr scott/tiger control=foo logfile=log', 但是不允许qlldr scott/tiger control=foo log', 即使参数 'log' 的位置正确。

  optionally enclosed by '"'
  将数据文件中的数据字段含有的引号“ " ”去掉,如果没有这段话,将会把“ " ”和字符合在一起导入数据库表中。

  指定不装载那一列
  LOAD DATA
  INFILE *
  INTO TABLE DEPT
  REPLACE
  FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
  (
    DEPTNO,
    FILLER_1 FILLER, // 下面的 "Something Not To Be Loaded" 将不会被装载
    DNAME,
    LOC
  )
  BEGINDATA
  20,Something Not To Be Loaded,Accounting,"Virginia,USA"

  position的列子
  LOAD DATA
  INFILE *
  INTO TABLE DEPT
  REPLACE
  (
    DEPTNO position(1:2),
    DNAME position(*:16), // 这个字段的开始位置在前一字段的结束位置
    LOC position(*:29),
    ENTIRE_LINE position(1:29)
  )
  BEGINDATA
  10Accounting Virginia,USA

  合并多行记录为一行记录
  LOAD DATA
  INFILE *
  concatenate 3 // 通过关键字concatenate 把几行的记录看成一行记录
  INTO TABLE DEPT
  replace
  FIELDS TERMINATED BY ','
  (
    DEPTNO,
    DNAME "upper(:dname)",
    LOC "upper(:loc)",
    LAST_UPDATED date 'dd/mm/yyyy'
  )
  BEGINDATA
  10,Sales, // 其实这3行看成一行 10,Sales,Virginia,1/5/2000
  Virginia,
  1/5/2000
  // 这列子用 continueif list="," 也可以 告诉sqlldr在每行的末尾找逗号 找到逗号就把下一行附加到上一行。

  载入每行的行号
  
load data
  infile *
  into table t
  replace
  (
    seqno RECNUM //载入每行的行号
    text Position(1:1024)
  )
  BEGINDATA
  fsdfasj //自动分配一行号给载入 表t 的seqno字段 此行为 1
  fasdjfasdfl // 此行为 2 ...

  跳过数据行
  可以用 "SKIP n" 关键字来指定导入时可以跳过多少行数据。如:
  LOAD DATA
  INFILE *
  INTO TABLE load_positional_data
  SKIP 5
  (
    data1 POSITION(1:5),
    data2 POSITION(6:15)
  )
  BEGINDATA
  11111AAAAAAAAAA
  22222BBBBBBBBBB

  提高 SQL*Loader 的性能
  1) 一个简单而容易忽略的问题是,没有对导入的表使用任何索引和/或约束(主键)。如果这样做,甚至在使用ROWS=参数时,会很明显降低数据库导入性能。
  2) 可以添加 DIRECT=TRUE来提高导入数据的性能。当然,在很多情况下,不能使用此参数。
  3) 通过指定 UNRECOVERABLE选项,可以关闭数据库的日志。这个选项只能和 direct 一起使用。
  4) 可以同时运行多个导入任务。

  常规导入与direct导入方式的区别
  常规导入可以通过使用 INSERT语句来导入数据。Direct导入可以跳过数据库的相关逻辑(DIRECT=TRUE),而直接将数据导入到数据文件中。

转载于:https://www.cnblogs.com/xd502djj/archive/2011/03/23/1992937.html

Sqlldr使用介绍相关推荐

  1. Oracle数据加载之sqlldr工具的介绍

    环境: 服务端:RHEL6.4 + Oracle 11.2.0.4 客户端:WIN10 + Oracle 11.2.0.1 client 目录: sqlldr语法 sqlldr实验准备 sqlldr常 ...

  2. sqlldr,将数据批量导入Oracle数据库

    哈喽,大家好,今天分享一个如何把文本数据快速导入到Oracle数据库的一个方法. 首先介绍一下sqlldr工具,它是由Oracle提供,专本用于把文本数据导入到Oracle数据库.它需要两个文件,一个 ...

  3. oracle sequrnce_Oracle Sqlldr简单用法

    Oracle数据库sqlload用法的相关知识是本文我们主要要介绍的内容,那么什么是sqlload呢?看完下面的例子我们就知道了.当用Oracle数据库处理百万级别数据时,选择sqlload应该是比较 ...

  4. 使用sqlldr导入文本数据到oracle

    1.sqlldr介绍 用法: SQLLDR keyword=value [,keyword=value,...]   有效的关键字:       userid -- ORACLE 用户名/口令     ...

  5. oracle数据库导入txt,oracle数据库导入TXT文件方法介绍

    客户端连接数据库导入 1. 安装有oracle客户端,配好监听. 2. 以oracle数据库app用户的表user_svc_info为例 CREATE TABLE USER_SVC_INFO( PHO ...

  6. oracle sqlldr详解,sqlldr详解

    Oracle 的SQL*LOADER可以将外部数据加载到数据库表中.下面是SQL*LOADER的基本特点: 1)能装入不同数据类型文件及多个数据文件的数据 2)可装入固定格式,自由定界以及可度长格式的 ...

  7. Oracle数据库导入csv文件(sqlldr命令行)

    1.说明 Oracle数据库导入csv文件, 当csv文件较小时, 可以使用数据库管理工具, 比如DBevaer导入到数据库, 当csv文件很大时, 可以使用Oracle提供的sqlldr命令行工具, ...

  8. sql loader导出数据和导入数据(sqlldr)

    一般我我们对表进行数据迁移的时候会用以下几种方法: 1. A表记录利用toad或者pl/sql工具将其导出为一条条分号隔开的insert语句,然后再执行插入到B表中 2.建立数据库间的dblink,然 ...

  9. SQL*Loader总结sqlldr

    由酸菜鱼记录,所有代码均经过测试.只是部分代码的效果在不同平台上会出现差异!有问题请:1#w1520.com[#替换成@],或者:提交建议 SQL*Loader总结 认识SQL*Loader SQL* ...

最新文章

  1. 一仅仅小蜜蜂(杭电2044)
  2. python | 删除两个指定字符串之间的内容
  3. 二阶偏微分方程组 龙格库塔法_数值方法(MATLAB版)(原书第3版)[Numerical Methods Using MATLAB,Third Edition]pdf...
  4. 使用requests库发起gbk编码的get请求
  5. hive使用适用场景_ 如何将Hive与HBase整合联用
  6. 夜间灯光数据的ARCGIS操作处理笔记
  7. 微信开发之测试号申请
  8. 微信小程序云函数服务器,微信小程序云函数使用的几点说明
  9. 自主实现sleep函数(代码实现)
  10. 【深圳】大湾区第三次.NET技术交流会(网络直播)
  11. 商品促销倒计时效果实现
  12. 41.Django快速上手
  13. java打字游戏课程设计_Java课程设计打字游戏.docx
  14. CAD中黑色实心柱子墙体画法步骤及方法
  15. LigoWave品牌的产品分类及项目选型
  16. ffmpeg开发之旅(4):MP3编码格式分析与lame库编译封装
  17. 基于matlab系统辨识工具箱,基于matlab的识别系统
  18. 应广PMS171B(1)--概述配置端口输出高低电平
  19. html右键菜单背景图片,鼠标右键的普通背景怎么更换为漂亮的菜单背景?
  20. 纵观虚拟现实在各行各业的应用,虚拟现实技术目前依然处在零星的散状的实验阶段。

热门文章

  1. CF - 741(C. Arpa’s overnight party and Mehrdad’s silent entering) 二分图构造
  2. POJ 1932 XYZZY (差分约束+传递闭包)
  3. chart绑定mysql数据源_MSChart图表之Chart组件 学习一篇(5个主要属性+数据源绑定)...
  4. 1.确保容器中的对象拷贝正确而高效
  5. 十大排序算法之冒泡排序
  6. mmap mprotect详解
  7. red hat linux挂载u盘,请问怎样在Red Hat 9.0中使用U盘?
  8. matlab 不单调 插值,三组无关数据进行MATLAB画三维图不采用插值的方法该怎么办...
  9. 贞子的在日本历史出现过的轨迹
  10. 【vue-number-scroll】数字逐渐增加或者减少的滚动解决方案