zoukankan      html  css  js  c++  java
  • sqlldr

    由于最近做一个项目 考虑到插入数据库效率的问题, 需要将 .csv格式的文本文件导入到 oracle数据库当中 。

     1 首先导入 oracle 的方法有很多 , 对于不同需求有不同的导入方式 , 我在这里就说一下  sqlldr 的方法 。  使用sqlldr 将文本文件导入 oracle中确切说只需要两步 。

     第一步:  写一个 ctl  格式的控制文件

          CTL 控制文件的内容 :  (我会写一个模板和一个样例)

      1) insert     --为缺省方式,在数据装载开始时要求表为空
      2) append  --在表中追加新记录
      3) replace  --删除旧记录(用 delete from table 语句),替换成新装载的记录
      4) truncate --删除旧记录(用 truncate table 语句),替换成新装载的记录

              模板 :

                     load data   --    1. 控制文件标识

                     infile 'xxx.csv'      --  2. 要导入的数据文件名  linuk系统路径:/.../...     windows系统路径:D:/....

                     insert  into  table   test   --  3.  将文件插入到数据库的 test 表中

                     fields terminated by ',' --  4.  用于分割一行中各个属性值的符号(例如每个属性值用逗号 分割 ,  ‘ ,’)

                     optionally enclosed by '"' --5 很多数据源的字段开始和结束都是带双引号的,这里是无视这些双引号,如果不写 optionally enclosed by '"'那么带有双引号的数据会插入到数据库表中

                     (id  , username ,passwprd ,......)    -- 6.  test表中对应的属性名

    2,在 cmd 命令窗口中写入导入语句     


    用法: 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)

     ->  sqlldr  userid = 用户名 / 密码 @ 数据库名    control = 之前写的ctl控制文件的地址     bad = E:/ bad.bad    log = E:/log.log   skip=1  rows=1000     errors=10000  direct=y

    作者:郑金圣
    本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。
  • 相关阅读:
    oracle 使用正则表达式获取字符串中包含的数字
    oracle 将逗号分隔的字符串转成多行记录
    sqlplus下 查看oracle 执行计划
    使用connect by 虚拟生成100条记录
    Lomsat gelral
    Legacy
    慢慢变小的序列(好题)
    Walls(扫描线)
    线段树求面积并,面积交,周长
    最小圆覆盖(随机增量||模拟退火)
  • 原文地址:https://www.cnblogs.com/zhengjinsheng/p/10956430.html
Copyright © 2011-2022 走看看