Oracle快速匯出平面檔案
轉載自:
/>
/>
-
CREATE OR REPLACE DIRECTORY "MYDIR" AS '/home/oracle/';
-
-
CREATE OR REPLACE TYPE dump_ot AS OBJECT
-
(
-
file_name VARCHAR2 (128),
-
directory_name VARCHAR2 (128),
-
no_records NUMBER,
-
session_id NUMBER,
-
start_dttm TIMESTAMP WITH TIME ZONE,
-
end_dttm TIMESTAMP WITH TIME ZONE
-
);
-
-
CREATE OR REPLACE TYPE dump_ntt AS TABLE OF dump_ot;
-
-
CREATE OR REPLACE FUNCTION DATA_UNLOAD (
-
p_source IN SYS_REFCURSOR,
-
p_filename IN VARCHAR2,
-
p_directory IN VARCHAR2,
-
p_unique_filename IN VARCHAR2 DEFAULT 'N',
-
p_create_log_file IN VARCHAR2 DEFAULT 'N')
-
RETURN dump_ntt
-
PIPELINED
-
PARALLEL_ENABLE(PARTITION p_source BY ANY)
-
AS
-
/*
-
p_source SQL query you spool
-
p_filename targe file name
-
p_directory targe Oracle directory
-
p_unique_filename create unique file name? Y/N (appends unique SID to p_filename) - useful only for parallel unload
-
p_create_log_file create log file? Y/N (creates separate log file and logs every 1mm rows) - has very small performance hit on the spool
-
*/
-
-
TYPE row_ntt IS TABLE OF VARCHAR2 (32767);
-
-
v_rows row_ntt;
-
v_file UTL_FILE.FILE_TYPE;
-
v_log_file UTL_FILE.FILE_TYPE;
-
v_buffer VARCHAR2 (32767);
-
v_sid VARCHAR (255);
-
v_name VARCHAR2 (255);
-
v_lines PLS_INTEGER := 0;
-
v_start_dttm TIMESTAMP WITH TIME ZONE := SYSTIMESTAMP;
-
v_end_dttm TIMESTAMP WITH TIME ZONE;
-
v_create_log BOOLEAN := FALSE;
-
-
c_eol CONSTANT VARCHAR2 (1) := CHR (10);
-
c_eollen CONSTANT PLS_INTEGER := LENGTH (c_eol);
-
c_maxline CONSTANT PLS_INTEGER := 32767;
-
c_log_limit CONSTANT PLS_INTEGER := 1000000;
-
BEGIN
-
v_sid := LPAD (SYS_CONTEXT ('USERENV', 'sid'), 10, '0');
-
v_name := p_filename;
-
-
IF TRIM (UPPER (p_create_log_file)) = 'Y'
-
THEN
-
v_create_log := TRUE;
-
END IF;
-
-
-- add SID (must be used for parallel spooling, single spooling or spooling across db-link creates alsway one file)
-
IF UPPER (p_unique_filename) = 'Y'
-
THEN
-
v_name := v_name || '_' || TO_CHAR (v_sid);
-
END IF;
-
-
v_file :=
-
UTL_FILE.FOPEN (p_directory,
-
v_name,
-
'w',
-
c_maxline);
-
-
IF v_create_log
-
THEN
-
v_log_file :=
-
UTL_FILE.FOPEN (p_directory,
-
v_name || '.LOG',
-
'w',
-
c_maxline);
-
UTL_FILE.PUT_LINE (
-
v_log_file,
-
TO_CHAR (v_start_dttm, 'DD-MON-YYYY HH24:MI:SS:FF3') || ' --> START');
-
UTL_FILE.FFLUSH (v_log_file);
-
END IF;
-
-
LOOP
-
FETCH p_source
-
BULK COLLECT INTO v_rows
-
LIMIT 10000;
-
-
FOR i IN 1 .. v_rows.COUNT
-
LOOP
-
IF LENGTHB (v_buffer) + c_eollen + LENGTHB (v_rows (i)) <= c_maxline
-
THEN
-
v_buffer := v_buffer || c_eol || v_rows (i);
-
ELSE
-
IF v_buffer IS NOT NULL
-
THEN
-
UTL_FILE.PUT_LINE (v_file, v_buffer);
-
END IF;
-
-
v_buffer := v_rows (i);
-
END IF;
-
END LOOP;
-
-
v_lines := v_lines + v_rows.COUNT;
-
-
IF v_create_log AND MOD (v_lines, c_log_limit) = 0
-
THEN
-
UTL_FILE.PUT_LINE (
-
v_log_file,
-
TO_CHAR (SYSTIMESTAMP, 'DD-MON-YYYY HH24:MI:SS:FF3')
-
|| ' --> '
-
|| v_lines);
-
UTL_FILE.FFLUSH (v_log_file);
-
END IF;
-
-
EXIT WHEN p_source%NOTFOUND;
-
END LOOP;
-
-
CLOSE p_source;
-
-
UTL_FILE.PUT_LINE (v_file, v_buffer);
-
UTL_FILE.FCLOSE (v_file);
-
v_end_dttm := SYSTIMESTAMP;
-
-
IF v_create_log
-
THEN
-
UTL_FILE.PUT_LINE (
-
v_log_file,
-
TO_CHAR (v_end_dttm, 'DD-MON-YYYY HH24:MI:SS:FF3')
-
|| ' --> '
-
|| v_lines);
-
UTL_FILE.PUT_LINE (
-
v_log_file,
-
TO_CHAR (v_end_dttm, 'DD-MON-YYYY HH24:MI:SS:FF3') || ' --> END');
-
UTL_FILE.FCLOSE (v_log_file);
-
END IF;
-
-
PIPE ROW (dump_ot (v_name,
-
p_directory,
-
v_lines,
-
v_sid,
-
v_start_dttm,
-
v_end_dttm));
-
RETURN;
-
END;
-
/
-
-
SELECT *
-
FROM TABLE (
-
DATA_UNLOAD (
-
CURSOR (
-
SELECT /*+ parallel(u,4) */
-
log_id
-
|| ','
-
|| typeid
-
|| ','
-
|| to_id
-
|| ','
-
|| to_msg
-
|| ','
-
|| userid
-
|| ','
-
|| nickname
-
|| ','
-
|| showing
-
|| ','
-
|| fromip
-
|| ','
-
|| TO_CHAR (createtime, 'yyyy-mm-dd HH24:mi:ss')
-
FROM mvbox_space.user_visit u),
-
'SAMPLE_SPOOL.TXT',
-
'MYDIR',
-
'Y',
- 'N'));
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29254281/viewspace-1771194/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SQLSERVER匯出TXT文字檔案,ORACLE SQL LOADER匯入TXT文字檔案SQLServerOracle
- 【ASK_ORACLE】一眼判斷出Oracle的dmp檔案是用expdp匯出還是exp匯出Oracle
- (十一)Electron 匯入匯出檔案
- java匯出CSV檔案Java
- js 匯出檔案流JS
- java匯出Excel檔案JavaExcel
- java模板匯出PDF檔案Java
- PHP 匯出 CSV 格式檔案PHP
- Swagger匯出Api文件檔案SwaggerAPI
- Android studio匯出apk檔案AndroidAPK
- Navicat如何匯入和匯出sql檔案SQL
- EasyExcel完成excel檔案的匯入匯出Excel
- oracle匯入dmp檔案win10怎麼操作_win10系統oracle如何匯入dmp檔案OracleWin10
- oracle匯入dmp檔案的2種方法Oracle
- 如何使用JavaScript匯入和匯出Excel檔案JavaScriptExcel
- Laravel-admin 匯出excel檔案LaravelExcel
- SQLite3 匯出 CSV 檔案SQLite
- POI匯出excel檔案加水印Excel
- fastadmin匯出圖片zip檔案AST
- Java整合FreeMarker匯出Pdf檔案Java
- dmfldr快速匯出
- Oracle 資料匯入匯出Oracle
- Oracle資料匯入匯出Oracle
- docker啟動的服務有匯出檔案的功能,檔案一直匯出失敗Docker
- C#中DataGrid匯出Excel檔案C#Excel
- VUE中使用 tableExport 匯出xlsx檔案VueExport
- PHP 匯出大資料 CSV 檔案PHP大資料
- 匯出處理耗時的檔案
- 如何把markdown檔案匯出為pdf
- Vue+ElementUI 匯出為PDF檔案VueUI
- vue3 匯出為Excel檔案VueExcel
- 匯入sql檔案出現亂碼SQL
- [Docker核心之容器、資料庫檔案的匯入匯出、容器映象的匯入匯出]Docker資料庫
- 如何將日誌檔案和二進位制檔案快速匯入HDFS?
- Oracle如何使用spool匯出utf8字符集的文字檔案Oracle
- 4242.全文檢索與檔案匯出試驗, ④檔案完整路徑,使用“匯出→資料夾” ,匯出為網址,無法使用...
- 生產裝置機臺檔案匯出,怎樣兼顧檔案的完整性和匯出效率?
- vue專案前端匯出word檔案(bug解決)Vue前端
- ffmpeg 匯出影片檔案中的音訊音訊