excel檔案內容匯入資料庫的問題及解決
今天需要導一些資料,從excel匯入到資料庫中。
沒有裝現成的plsqldev,只能用sql*loader來弄了。
首先我把excel檔案的內容轉換成csv檔案,以逗號分隔,在另存外excel檔案的時候有那個選項。
然後我在目標庫中建立瞭如下的表。
create table sql_summary(sql_time varchar2(100),sql_id varchar2(100),cpu_time varchar2(100),disk_time varchar2(100),exec_time varchar2(100),elapsed_s number);
資料類似下面的格式:
140320_165505,gk9u1b5j5702c,1.18E+10,111636718,691,25.14
140320_205539,gk9u1b5j5702c,1.18E+10,110500905,682,25.95
140321_005607,gk9u1b5j5702c,3049428380,29109514,181,22.07
140321_045625,gk9u1b5j5702c,1.21E+10,114246906,705,22.96
140321_085641,gk9u1b5j5702c,1.16E+10,111346877,687,22.9
140319_045158,gpjv97kkg4fv9,50516321,4705112,1,163.46
140313_123928,gqfnh6bf8h2rc,26741932,349150,4,20.4
140317_004719,gs5bhxa1gamww,500924,143350,1,9.09
140316_084548,gt03f296r4cys,11761212,309219,1,33.29
140314_204223,gun4phkc6tkza,23715395,0,1,23.72
140318_125028,gun4phkc6tkza,22455586,0,1,22.47
140318_165049,gun4phkc6tkza,23880370,1,1,23.89
140319_125232,gun4phkc6tkza,23246466,0,1,23.25
140314_124138,gusarx703b7um,50467329,356132,2,56.08
140314_204223,gv6gaza6da96k,69001509,2860,1,73.75
140316_124606,gv6gaza6da96k,69980362,2834,1,74.82
140320_205539,gwpudzhp5zazc,2907558,629750,1,71.79
建立控制檔案如下
LOAD DATA
INFILE a.txt
INTO TABLE sql_summary
FIELDS TERMINATED BY ","
TRAILING NULLCOLS
(sql_time,sql_id,cpu_time,disk_time,exec_time,elapsed_s)
然後呼叫sql*loader來匯入了。粗放一點,其他的日誌檔案就不指定了。
sqlldr control=a.ctl
也沒有報錯,就提示了一行資訊。但是也不算錯誤,檢視錶裡,沒有資料
DUM1102 /oravl01/oracle> sqlldr control='/oravl01/oracle/a.ctl'
SQL*Loader: Release 11.2.0.2.0 - Production on Fri Mar 21 17:16:58 2014
Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved.
Commit point reached - logical record count 64
對於上面的資訊,查了下,可以在控制檔案中加入這個選項來可控制commit的頻度。最大目前是165.
#OPTIONS (ROWS=100)
設定了以後還是不行。
最後百思不得其解,看看檔案的內容吧,vi 一看,原來是dos格式的問題
140314_124138,007yxsxdz7p0h,13721913,165027,1,30.93^M
140314_164158,007yxsxdz7p0h,20656859,330086,2,19.7^M
140314_204223,007yxsxdz7p0h,20669858,330198,2,21.43^M
140315_124337,007yxsxdz7p0h,11427263,165103,1,20.41^M
140315_164358,007yxsxdz7p0h,20966812,330229,2,22.38^M
140315_204420,007yxsxdz7p0h,10631384,165132,1,20.66^M
用dosux或者dos2unix格式化一把。
重新試一次。資料算是匯入了。:)
指令碼如下。
LOAD DATA
INTO TABLE sql_summary
FIELDS TERMINATED BY ","
TRAILING NULLCOLS
(sql_time,sql_id,cpu_time,disk_time,exec_time,elapsed_s)
sqlldr control=a.ctl data=a.data
DUM1102 /oravl01/oracle> sqlldr control=a.ctl data=a.data
SQL*Loader: Release 11.2.0.2.0 - Production on Fri Mar 21 17:36:44 2014
Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved.
Commit point reached - logical record count 64
Commit point reached - logical record count 128
Commit point reached - logical record count 192
Commit point reached - logical record count 256
Commit point reached - logical record count 320
Commit point reached - logical record count 384
Commit point reached - logical record count 448
Commit point reached - logical record count 512
Commit point reached - logical record count 576
Commit point reached - logical record count 640
Commit point reached - logical record count 704
Commit point reached - logical record count 768
Commit point reached - logical record count 832
Commit point reached - logical record count 896
Commit point reached - logical record count 922
DUM1102 /oravl01/oracle> sqlplus
SQL*Plus: Release 11.2.0.2.0 Production on Fri Mar 21 17:36:51 2014
Copyright (c) 1982, 2010, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.2.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL> select count(*)from sql_summary;
COUNT(*)
----------
922
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/23718752/viewspace-1126988/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 解決Excel資料匯入sqlite中的中文亂碼問題ExcelSQLite
- 將dataGridView內容匯出到Excel檔案ViewExcel
- Java HDFS API 追加檔案寫入內容異常問題的解決JavaAPI
- excel檔案中的資料匯入Oracle資料庫的幾種方法ExcelOracle資料庫
- apache日誌內容匯入資料庫Apache資料庫
- php讀取excel檔案資料的匯入和匯出PHPExcel
- 關於資料表結構sql檔案匯入mysql資料庫的問題?MySql資料庫
- TP5.1excel匯入資料庫的程式碼?php excel如何匯入資料庫?Excel資料庫PHP
- Net.Core匯入EXCel檔案裡的資料Excel
- 匯入excel檔案Excel
- excel 匯入sqlyog資料庫ExcelSQL資料庫
- SSIS中匯入Excel資料到資料庫的一個常見小問題Excel資料庫
- PHP 匯入資料庫 sql 檔案PHP資料庫SQL
- 資料庫遠端檔案匯入資料庫
- 將excel表格匯入資料庫Excel資料庫
- 資料庫config.php檔案內容解釋及替換方法資料庫PHP
- java程式碼實現excel檔案資料匯入JavaExcel
- 匯入excel資源到資料庫Excel資料庫
- maatwebsite/excel": "^3.1 匯入excel 問題WebExcel
- 清空listener.log檔案內容後,內容不能寫入listener.log檔案的解決方法
- EasyExcel完成excel檔案的匯入匯出Excel
- html匯入導航欄本地檔案解決跨域問題HTML跨域
- Oracle工具之sqlldr的使用--如何將文字檔案或Excel中的資料匯入資料庫OracleSQLExcel資料庫
- 將Excel檔案匯入資料庫(POI+Excel+MySQL+jsp頁面匯入)第一次優化Excel資料庫MySqlJS優化
- EXP匯出資料檔名稱重複問題的解決
- php做EXCEL資料匯出匯入開發的一些小問題PHPExcel
- java 從EXCEL匯入到資料庫JavaExcel資料庫
- 從Excel到匯入MYSQL資料庫ExcelMySql資料庫
- Excel匯入Sqlserver資料庫指令碼ExcelSQLServer資料庫指令碼
- 土製Excel匯入匯出及相關問題探討Excel
- 小程式批次匯入excel資料,雲開發資料庫匯出cvs亂碼解決方案Excel資料庫
- Java POI匯入Excel檔案JavaExcel
- 解決excel開啟.csv檔案亂碼問題Excel
- 將 SAP ABAP 內表內容本地匯出成 Excel 檔案試讀版Excel
- 安裝mysql資料庫及問題解決方法MySql資料庫
- [Docker核心之容器、資料庫檔案的匯入匯出、容器映象的匯入匯出]Docker資料庫
- 將excel檔案內容儲存到資料庫,並可以實時在前端檢視(不必生成檔案)Excel資料庫前端
- Excel檔案彈出隱私問題警告的解決方法Excel