程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> oracle utl_file包讀取數據的實例

oracle utl_file包讀取數據的實例

編輯:Oracle數據庫基礎

Oracle utl_file包相信大家都有一定的了解,下面為您介紹的是Oracle utl_file包讀取數據的實現方法,如果您對Oracle utl_file包方面感興趣的話,不妨一看。

  1. create or replace directory MY_DIR as '/usr/test/';  
  2. create or replace function f_exportTxt(  
  3.   --傳入參數  
  4.   i_query in varchar2,  
  5.   i_separator in varchar2,  
  6.   i_dir in varchar2,  
  7.   i_filename in varchar2  
  8. ) return number  
  9. is  
  10.   /**  
  11.   ** 函數名:f_exportTxt  
  12.   ** 參數:1.i_query 查詢sql語句; 2.i_separator 分隔符,默認為',' ;  
  13.   **      3.i_dir存放目錄; 4.i_filename文件名,默認在文件名前加上yyyymmddhh24mi  
  14.   ** 返回: 大於等於0即為寫入文件記錄數,負為異常  
  15.   ** 功能: 用戶數據抽取,並生成文件到指定目錄下  
  16.   ** 備注:  
  17.   ** 作者:lingo  
  18.   ** 修改日期:2010-04-15  
  19.   **/  
  20.   --定義參數  
  21.   v_file utl_file.file_type;  
  22.   v_theCursor integer default dbms_sql.open_cursor;  
  23.   v_columnValue varchar2(2000); --臨時(列值)  
  24.   v_colCnt number default 0; --列總數  
  25.   v_separator varchar2(10) default ',';--分隔符,默認為#@  
  26.   v_cnt number default 0;  --記錄總數  
  27.   v_filename varchar2(100);--時間  
  28.   v_status integer;--執行SQL後返回狀態值  
  29.   v_count number default 10000 ; --每次查詢的數量,大於該數量則多次讀取數據到游標  
  30.   v_tmp number ;--臨時(總記錄數,通過SQL統計算出,假如v_cnt不等於v_tmp,則導出有誤)  
  31.   v_sql varchar2(2000) ; --組合sql語句  
  32.   v_loops number ; --循環次數  
  33. begin  
  34.   --select to_char(sysdate,'yyyymmddhh24mi') into v_filename from dual; --取時間年月日時分做文件名前綴  
  35.   v_filename :='';  
  36.   v_filename :v_filename||i_filename ; --組建文件名  
  37.   v_sql := 'select count(''x'') from (' ||i_query||')' ;--統計總數  
  38.   execute immediate v_sql into v_tmp;  
  39.   select trunc(v_tmp/v_count) into v_loops from dual ; --循環次數  
  40.   if mod(v_tmp,v_count) > 0 then  
  41.     v_loops :v_loops+1;  
  42.   end if;  
  43.   v_file :utl_file.fopen(i_dir,v_filename,'W'); --打開文件  
  44.   for i in 1 .. v_loops loop  
  45.       v_sql := 'select * from ( select m.*,rownum r fr ......   
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved