乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      oracle sql*loader使用方法

       昵稱58323 2008-07-24

      oracle loader

      我需要將文本文件導入ORACLE,需要建立一個表然后用LOADER導入,以前都是寫到SQL里,我覺得那樣真的很麻煩了。。

      Oracle SQL*Loader 使用指南(轉(zhuǎn)載)

      SQL*Loader是Oracle數(shù)據(jù)庫導入外部數(shù)據(jù)的一個工具.它和DB2的Load工具相似,但有更多的選擇,它支持變化的加載模式,可選的加載及多表加載.

      如何使用 SQL*Loader 工具
      我們可以用Oracle的sqlldr工具來導入數(shù)據(jù)。例如:
      sqlldr scott/tiger control=loader.ctl
      控制文件(loader.ctl) 將加載一個外部數(shù)據(jù)文件(含分隔符). loader.ctl如下:
      load data
      infile 'c:\data\mydata.csv'
      into table emp
      fields terminated by "," optionally enclosed by '"'
      ( empno, empname, sal, deptno )

      mydata.csv 如下:
      10001,"Scott Tiger", 1000, 40
      10002,"Frank Naude", 500, 20
      下面是一個指定記錄長度的示例控制文件。"*" 代表數(shù)據(jù)文件與此文件同名,即在后面使用BEGINDATA段來標識數(shù)據(jù)。
      load data
      infile *
      replace
      into table departments
      ( dept position (02:05) char(4),
      deptname position (08:27) char(20)
      )
      begindata
      COSC COMPUTER SCIENCE
      ENGL ENGLISH LITERATURE
      MATH MATHEMATICS
      POLY POLITICAL SCIENCE
      Unloader這樣的工具
      Oracle 沒有提供將數(shù)據(jù)導出到一個文件的工具。但是,我們可以用SQL*Plus的select 及 format 數(shù)據(jù)來輸出到一個文件:
      set echo off newpage 0 space 0 pagesize 0 feed off head off trimspool on
      spool oradata.txt
      select col1 || ',' || col2 || ',' || col3
      from tab1
      where col2 = 'XYZ';
      spool off

      另外,也可以使用使用 UTL_FILE PL/SQL 包處理:
      rem Remember to update initSID.ora, utl_file_dir='c:\oradata' parameter
      declare
      fp utl_file.file_type;
      begin
      fp := utl_file.fopen('c:\oradata','tab1.txt','w');
      utl_file.putf(fp, '%s, %s\n', 'TextField', 55);
      utl_file.fclose(fp);
      end;
      /

      當然你也可以使用第三方工具,如SQLWays ,TOAD for Quest等。

      加載可變長度或指定長度的記錄
      如:
      LOAD DATA
      INFILE *
      INTO TABLE load_delimited_data
      FIELDS TERMINATED BY "," OPTIONALLY ENCLOSED BY '"'
      TRAILING NULLCOLS
      ( data1,
      data2
      )
      BEGINDATA
      11111,AAAAAAAAAA
      22222,"A,B,C,D,"

      下面是導入固定位置(固定長度)數(shù)據(jù)示例:
      LOAD DATA
      INFILE *
      INTO TABLE load_positional_data
      ( data1 POSITION(1:5),
      data2 POSITION(6:15)
      )
      BEGINDATA
      11111AAAAAAAAAA
      22222BBBBBBBBBB

      跳過數(shù)據(jù)行:
      可以用 "SKIP n" 關鍵字來指定導入時可以跳過多少行數(shù)據(jù)。如:
      LOAD DATA
      INFILE *
      INTO TABLE load_positional_data
      SKIP 5
      ( data1 POSITION(1:5),
      data2 POSITION(6:15)
      )
      BEGINDATA
      11111AAAAAAAAAA
      22222BBBBBBBBBB

      導入數(shù)據(jù)時修改數(shù)據(jù):
      在導入數(shù)據(jù)到數(shù)據(jù)庫時,可以修改數(shù)據(jù)。注意,這僅適合于常規(guī)導入,并不適合 direct導入方式.如:
      LOAD DATA
      INFILE *
      INTO TABLE modified_data
      ( rec_no "my_db_sequence.nextval",
      region CONSTANT '31',
      time_loaded "to_char(SYSDATE, 'HH24:MI')",
      data1 POSITION(1:5) ":data1/100",
      data2 POSITION(6:15) "upper(:data2)",
      data3 POSITION(16:22)"to_date(:data3, 'YYMMDD')"
      )
      BEGINDATA
      11111AAAAAAAAAA991201
      22222BBBBBBBBBB990112

      LOAD DATA
      INFILE 'mail_orders.txt'
      BADFILE 'bad_orders.txt'
      APPEND
      INTO TABLE mailing_list
      FIELDS TERMINATED BY ","
      ( addr,
      city,
      state,
      zipcode,
      mailing_addr "decode(:mailing_addr, null, :addr, :mailing_addr)",
      mailing_city "decode(:mailing_city, null, :city, :mailing_city)",
      mailing_state
      )

      將數(shù)據(jù)導入多個表:
      如:
      LOAD DATA
      INFILE *
      REPLACE
      INTO TABLE emp
      WHEN empno != ' '
      ( empno POSITION(1:4) INTEGER EXTERNAL,
      ename POSITION(6:15) CHAR,
      deptno POSITION(17:18) CHAR,
      mgr POSITION(20:23) INTEGER EXTERNAL
      )
      INTO TABLE proj
      WHEN projno != ' '
      ( projno POSITION(25:27) INTEGER EXTERNAL,
      empno POSITION(1:4) INTEGER EXTERNAL
      )

      導入選定的記錄:
      如下例: (01) 代表第一個字符, (30:37) 代表30到37之間的字符:
      LOAD DATA
      INFILE 'mydata.dat' BADFILE 'mydata.bad' DISCARDFILE 'mydata.dis'
      APPEND
      INTO TABLE my_selective_table
      WHEN (01) <> 'H' and (01) <> 'T' and (30:37) = '19991217'
      (
      region CONSTANT '31',
      service_key POSITION(01:11) INTEGER EXTERNAL,
      call_b_no POSITION(12:29) CHAR
      )

      導入時跳過某些字段:
      可用 POSTION(x:y) 來分隔數(shù)據(jù). 在Oracle8i中可以通過指定 FILLER 字段實現(xiàn)。FILLER 字段用來跳過、忽略導入數(shù)據(jù)文件中的字段.如:
      LOAD DATA
      TRUNCATE INTO TABLE T1
      FIELDS TERMINATED BY ','
      ( field1,
      field2 FILLER,
      field3
      )

      導入多行記錄:
      可以使用下面兩個選項之一來實現(xiàn)將多行數(shù)據(jù)導入為一個記錄:

      CONCATENATE: - use when SQL*Loader should combine the same number of physical records together to form one logical record.

      CONTINUEIF - use if a condition indicates that multiple records should be treated as one. Eg. by having a '#' character in column 1.

      SQL*Loader 數(shù)據(jù)的提交:
      一般情況下是在導入數(shù)據(jù)文件數(shù)據(jù)后提交的。
      也可以通過指定 ROWS= 參數(shù)來指定每次提交記錄數(shù)。

      提高 SQL*Loader 的性能:
      1) 一個簡單而容易忽略的問題是,沒有對導入的表使用任何索引和/或約束(主鍵)。如果這樣做,甚至在使用ROWS=參數(shù)時,會很明顯降低數(shù)據(jù)庫導入性能。
      2) 可以添加 DIRECT=TRUE來提高導入數(shù)據(jù)的性能。當然,在很多情況下,不能使用此參數(shù)。
      3) 通過指定 UNRECOVERABLE選項,可以關閉數(shù)據(jù)庫的日志。這個選項只能和 direct 一起使用。
      4) 可以同時運行多個導入任務.

      常規(guī)導入與direct導入方式的區(qū)別:
      常規(guī)導入可以通過使用 INSERT語句來導入數(shù)據(jù)。Direct導入可以跳過數(shù)據(jù)庫的相關邏輯(DIRECT=TRUE),而直接將數(shù)據(jù)導入到數(shù)據(jù)文件中。

      *******************************

      學習Oracle SQL loader 的使用(1)

      一:sql loader 的特點

          oracle自己帶了很多的工具可以用來進行數(shù)據(jù)的遷移、備份和恢復等工作。但是每個工具都有自己的特點。比如說exp和imp可以對數(shù)據(jù)庫中的數(shù)據(jù)進行導出和導出的工作,是一種很好的數(shù)據(jù)庫備份和恢復的工具,因此主要用在數(shù)據(jù)庫的熱備份和恢復方面。有著速度快,使用簡單,快捷的優(yōu)點;同時也有一些缺點,比如在不同版本數(shù)據(jù)庫之間的導出、導入的過程之中,總會出現(xiàn)這樣或者那樣的問題,這個也許是oracle公司自己產(chǎn)品的兼容性的問題吧。

          sql loader 工具卻沒有這方面的問題,它可以把一些以文本格式存放的數(shù)據(jù)順利的導入到oracle數(shù)據(jù)庫中,是一種在不同數(shù)據(jù)庫之間進行數(shù)據(jù)遷移的非常方便而且通用的工具。缺點就速度比較慢,另外對blob等類型的數(shù)據(jù)就有點麻煩了。

      二:sql loader 的幫助

      C:\>sqlldr

      SQL*Loader: Release 9.2.0.1.0 - Production on 星期六 10月 9 14:48:12 2004

      Copyright (c) 1982, 2002, Oracle Corporation.  All rights reserved.


      用法: SQLLDR keyword=value [,keyword=value,...]

      有效的關鍵字:

          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
      (默認: 常規(guī)路徑 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: 命令行參數(shù)可以由位置或關鍵字指定。前者的例子是 'sqlloadscott/tiger foo'; 后一種情況的一個示例是 'sqlldr

      control=foouserid=scott/tiger'.位置指定參數(shù)的時間必須早于但不可遲于由關鍵字指定的參數(shù)。例如,允許 'sqlldr scott/tiger

      control=foo logfile=log', 但是不允許 'sqlldr scott/tiger control=foo log', 即使參數(shù) 'log' 的位置正確。

      C:\>

      *************************************

      學習Oracle SQL loader 的使用(2)

      上接:學習Oracle SQL loader 的使用(1)

      三:sql loader使用例子

      a)SQLLoader將 Excel 數(shù)據(jù)導出到 Oracle

      1.創(chuàng)建SQL*Loader輸入數(shù)據(jù)所需要的文件,均保存到C:\,用記事本編輯:

      控制文件:input.ctl,內(nèi)容如下:
       
        load data           --1、控制文件標識
        infile 'test.txt'       --2、要輸入的數(shù)據(jù)文件名為test.txt
        append into table test    --3、向表test中追加記錄
        fields terminated by X'09'  --4、字段終止于X'09',是一個制表符(TAB)
        (id,username,password,sj)   -----定義列對應順序
       
      a、insert,為缺省方式,在數(shù)據(jù)裝載開始時要求表為空
      b、append,在表中追加新記錄
      c、replace,刪除舊記錄,替換成新裝載的記錄
      d、truncate,同上
       
      在DOS窗口下使用SQL*Loader命令實現(xiàn)數(shù)據(jù)的輸入
       
      C:\>sqlldr userid=system/manager control=input.ctl
        默認日志文件名為:input.log
      默認壞記錄文件為:input.bad


      2.還有一種方法

      可以把EXCEL文件另存為CSV(逗號分隔)(*.csv),控制文件就改為用逗號分隔
      LOAD DATA
      INFILE 'd:\car.csv'
      APPEND  INTO TABLE t_car_temp
      FIELDS TERMINATED BY ","
      (phoneno,vip_car)


      b)在控制文件中直接導入數(shù)據(jù)

      1、控制文件test.ctl的內(nèi)容

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

      2、執(zhí)行導入命令
      C:\>sqlldr userid=system/manager control=test.ctl

        本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多