Orale数据导入

  • SQL*LOADER的使用方法

  • 用法: 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  (默认 NO
    T_USED)
    columnarrayrows -- 直接路径列数组的行数  (默认 5000)
    streamsize -- 直接路径流缓冲区的大小 (以字节计)  (默认 256000)
    multithreading -- 在直接路径中使用多线程
    resumable -- 启用或禁用当前的可恢复会话  (默认 FALSE)
    resumable_name -- 有助于标识可恢复语句的文本字符串
    resumable_timeout -- RESUMABLE 的等待时间 (以秒计)  (默认 7200)
    date_cache -- 日期转换高速缓存的大小 (以条目计)  (默认 1000)

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

    示例,定义sqlldr.ctl文件

    load data
    CHARACTERSET ZHS16GBK
    infile 'c:\operator.txt'
    append into table demo.operator
    fields terminated by '|'
    trailing nullcols
    (opercode,name)

    operator.txt文件内容

    acb001|23232|
    cde002|45678|

    在控制台执行命令 sqlldr userid=demo/demo@demo control=sqlldr.ctl即可导入文件,导入完成后查看是否有bad文件,检查出错的原因

    使用并发和关闭日志
    sqlldr userid=/ control=sqlldr.ctl direct=true parallel=true
    当加载大量数据时(大约超过10GB),最好抑制日志的产生:
    ALTER TABLE operator nologging;
    这样不产生REDO LOG,可以提高效率。然后在CONTROL文件中load data上面加一行:unrecoverable 此选项必须要与DIRECT共同应用。

    开启并行和关闭日志导入时:可以显著提高速度,经过测试导入1.6g的文件,2kw条数据,需4分钟即可完成. 测试的系统是E40 pentium 2G内存 win7系统

猜你喜欢

转载自cyeboss.iteye.com/blog/1612880