日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

sqlldr用法

系統 1709 0

sql loader可以把一些以文本格式存放的數據順利的導入到oracle數據庫中,是一種在不同數據庫之間進行數據遷移的非常方便而且通用的工具。缺點就速度比較慢,另外對blob等類型的數據就有點麻煩了。
用法: SQLLDR keyword=value [,keyword=value,...]

在命令行下執行 Oracle? 的 sqlldr 命令,可以看到它的詳細參數說明,要著重關注以下幾個參數:

userid -- Oracle 的 username/password[@servicename]
control -- 控制文件,可能包含表的數據
-------------------------------------------------------------------------------------------------
log -- 記錄導入時的日志文件,默認為 控制文件(去除擴展名).log
bad -- 壞數據文件,默認為 控制文件(去除擴展名).bad
data -- 數據文件,一般在控制文件中指定。用參數控制文件中不指定數據文件更適于自動操作
errors -- 允許的錯誤記錄數,可以用他來控制一條記錄都不能錯
rows -- 多少條記錄提交一次,默認為 64
skip -- 跳過的行數,比如導出的數據文件前面幾行是表頭或其他描述

還有更多的 sqlldr 的參數說明請參考:sql loader的用法。


用例子來演示 sqlldr 的使用,有兩種使用方法:

1. 只使用一個控制文件,在這個控制文件中包含數據
2. 使用一個控制文件(作為模板) 和一個數據文件


下面來看示例

  1. create ? table ?users( ??
  2. user_id?number,??????????? --用戶?ID ??
  3. user_name?varchar2(50),??? --用戶名 ??
  4. login_times?number,??????? --登陸次數 ??
  5. last_login? date ??????????? --最后登錄日期 ??
  6. ) ??
  7. ??
  8. insert ? into ?users? values (1, 'Unmi' ,3,sysdate); ??
  9. ??
  10. insert ? into ?users? values (2, NULL ,5,to_date( '2008-10-15' , 'YYYY-MM-DD' )); ??
  11. ??
  12. insert ? into ?users? values (3, '隔葉黃鶯' ,8,to_date( '2009-01-02' , 'YYYY-MM-DD' )); ??
  13. ??
  14. insert ? into ?users? values (5, '不知秋' ,1,to_date( '2008-12-23' , 'YYYY-MM-DD' ));
第二種方式: 使用一個控制文件(作為模板) 和一個數據文件

1) 建立數據文件,我們這里用 PL/SQL Developer 導出表 users 的記錄為 users_data.csv 文件

建立一個控制文件 users.ctl,內容如下:
Users.ctl代碼 復制代碼
  1. OPTIONS?(skip= 1 ,rows= 128 )?--?sqlldr?命令顯示的選項可以寫到這里邊來,skip= 1 ?用來跳過數據中的第一行 ??
  2. LOAD?DATA ??
  3. INFILE? "users_data.csv" ?--指定外部數據文件,可以寫多個?INFILE? "another_data_file.csv" ?指定多個數據文件,也可以在此處不寫,在后面指定 ??
  4. --這里還可以使用?BADFILE、DISCARDFILE?來指定壞數據和丟棄數據的文件, ??
  5. truncate?--操作類型,用?truncate?table?來清除表中原有記錄 ??
  6. INTO?TABLE?users?--?要插入記錄的表 ??
  7. Fields?terminated?by? "," ?--?數據中每行記錄用? "," ?分隔 ??
  8. Optionally?enclosed?by? '"' ?--?數據中每個字段用? '"' ?框起,比如字段中有? "," ?分隔符時 ??
  9. trailing?nullcols?--表的字段沒有對應的值時允許為空 ??
  10. ( ??
  11. virtual_column?FILLER,?--這是一個虛擬字段,用來跳過由?PL/SQL?Developer?生成的第一列序號 ??
  12. user_id?number,?--字段可以指定類型,否則認為是?CHARACTER?類型,?log?文件中有顯示 ??
  13. user_name, ??
  14. login_times, ??
  15. last_login?DATE? "YYYY-MM-DD?HH24:MI:SS" ?--?指定接受日期的格式,相當用?to_date()?函數轉換 ??
  16. ) ??
  17. 說明:在操作類型?truncate?位置可用以下中的一值: ??
  18. ??
  19. 1 )?insert?????--為缺省方式,在數據裝載開始時要求表為空 ??
  20. 2 )?append??--在表中追加新記錄 ??
  21. 3 )?replace??--刪除舊記錄(用?delete?from?table?語句),替換成新裝載的記錄 ??
  22. 4 )?truncate?--刪除舊記錄(用?truncate?table?語句),替換成新裝載的記錄



執行命令

  1. sqlldr?userid=scott/anwei@orcl?control=user.ctl?data=user.cvs??log=user.log

?


執行完 sqlldr 后希望能留意一下生成的幾個文件,如 users.log 日志文件、users.bad 壞數據文件等。特別是要看看日志文件,從中可讓你更好的理解 Sql Loader,里面有對控制文件的解析、列出每個字段的類型、加載記錄的統計、出錯原因等信息。

sqlldr用法


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 宜川县| 监利县| 潍坊市| 长葛市| 芷江| 淮安市| 黄梅县| 邮箱| 巨野县| 枝江市| 龙井市| 山东省| 浦江县| 苏尼特右旗| 岑巩县| 阳谷县| 温州市| 称多县| 阿坝县| 漳平市| 宝山区| 腾冲县| 双城市| 泰州市| 金门县| 高州市| 盐池县| 密山市| 十堰市| 南川市| 万山特区| 伊通| 普格县| 腾冲县| 遂平县| 牡丹江市| 金山区| 娱乐| 曲麻莱县| 西峡县| 瑞安市|