色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

在oracle9i,如何在PL/SQL中讀寫文件

瀏覽:111日期:2023-11-20 19:20:10
PL/SQL 3.3以上的版本中,UTL_FILE包答應用戶通過PL/SQL讀寫操作系統文件。如下: declarefile_handle UTL_FILE.FILE_TYPE;beginfile_handle := UTL_FILE.FOPEN('TMP', '文件名', 'w',[1-32767]); ;--四個參數:目錄,文件名,打開方式,最大行數(默認為2000)UTL_FILE.PUTF(file_handle, '寫入的信息n');UTL_FILE.FCLOSE(file_handle);exceptionWHEN utl_file.invalid_path THENraise_application_error(-20000, 'ERROR: Invalid path for file or path not in INIT.ORA.');end; PutF()過程用來以指定格式把文本寫入一個文件Put_Line()過程把一個指定的字符串寫入文件并在文件中開始新的一行9i中函數說明:UTL_FILE.FOPEN ( location IN VARCHAR2, filename IN VARCHAR2, open_mode IN VARCHAR2, max_linesize IN BINARY_INTEGER) RETURN file_type; Parameters Description location (IN) The Directory location of the source file, a DIRECTORY_NAME from the; ALL_DIRECTORIES view (case sensitive) filename File name, including extension (file type), without directory path. In Unix,the filename cannot end with /. 一個使用文件的測試1、用sys用戶登錄到數據庫(ora9i):conn sys/orcl@eai01 as sysdba2、在sqlplus中運行create or replace directory TMP as 'd:testtmp'; 在sqlplus中運行grant read on directory TMP to public3、在scott用戶下建立存儲過程如:pReadFileTestCREATE OR REPLACE PROCEDURE pReadFileTest; (FPATH IN STRING,FNAME IN STRING,MAX_NUM IN NUMBER) IS FILE_HANDLE UTL_FILE.FILE_TYPE; TEXT_BUFFER STRING(1000); LINE_NUM NUMBER;BEGIN DBMS_OUTPUT.PUT_LINE('INPUT PATH='FPATH); DBMS_OUTPUT.PUT_LINE('INPUT FILENAME='FNAME); LINE_NUM :=0; BEGIN FILE_HANDLE := UTL_FILE.FOPEN(FPATH,FNAME,'R',MAX_NUM); LOOP LINE_NUM:= LINE_NUM + 1; UTL_FILE.GET_LINE(FILE_HANDLE,TEXT_BUFFER); DBMS_OUTPUT.PUT_LINE('LINE'LINE_NUM' : 'TEXT_BUFFER); END LOOP; EXCEPTION WHEN NO_DATA_FOUND THEN RETURN; WHEN UTL_FILE.INVALID_PATH THEN DBMS_OUTPUT.PUT_LINE('INVALID PATH'); WHEN UTL_FILE.INVALID_MODE THEN DBMS_OUTPUT.PUT_LINE('INVALID MODE'); WHEN UTL_FILE.INVALID_FILEHANDLE THEN DBMS_OUTPUT.PUT_LINE('INVALID FILEHANDLE'); WHEN UTL_FILE.INVALID_OPERATION THEN DBMS_OUTPUT.PUT_LINE('INVALID OPERATION'); WHEN UTL_FILE.READ_ERROR THEN DBMS_OUTPUT.PUT_LINE('READ ERROR'); WHEN UTL_FILE.WRITE_ERROR THEN DBMS_OUTPUT.PUT_LINE('WRITE ERROR'); WHEN UTL_FILE.INTERNAL_ERROR THEN DBMS_OUTPUT.PUT_LINE('INTERNAL ERROR'); WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(SQLERRM); END;EXCEPTIONWHEN OTHERS THENDBMS_OUTPUT.PUT_LINE('OTHER ERROR='SQLERRM);END pReadFileTest;4、在sqlplus中運行set serveroutput on5、exec pReadFileTest('TMP','A.TXT','R')6、正常輸出小結:在9i中可以不在init.ora中增加utl_file_dir目錄,而是在sys用戶下創建一個directory目錄(實際上是在sys用戶下的dir$表中增加一個對應的OS_PATH),然后將對該directory對象的讀/寫操作的權限grant給public。
標簽: Oracle 數據庫
相關文章:
主站蜘蛛池模板: 成人国产网站v片免费观看 成人国产午夜在线视频 | 国产色a在线观看 | 亚洲欧美日本综合一区二区三区 | 亚洲伊人久久综合影院2021 | 99久久精品免费看国产免费 | 国产成人a毛片 | 在线视频观看国产 | 亚洲高清视频在线播放 | 精品精品国产欧美在线观看 | 国产国语一级毛片全部 | 国产成人亚洲综合 | 亚洲午夜久久久久影院 | 一本大道香蕉久在线不卡视频 | 欧美激情第一欧美在线 | 全部免费的毛片视频观看 | 欧美一区二区精品 | 99久久精品免费看国产高清 | 亚洲视频自拍 | 久久青草免费免费91线频观看 | 欧美怡红院在线 | 久热香蕉精品视频在线播放 | 国产成人亚洲精品影院 | 久久不见久久见免费影院www日本 | 狠狠88综合久久久久综合网 | 亚洲人成网站在线观看播放 | 涩涩网站 | 亚洲精品www久久久久久久软件 | 亚洲厕拍 | 欧美成人免费观看的 | 亚洲第一色网 | 日韩欧美综合 | 国产精品自在欧美一区 | 亚洲精品a | 国产网站精品 | 视频一区在线免费观看 | 日本久久香蕉一本一道 | 一级做人爱a视频正版免费 一级做性色a爱片久久片 | 91精品视品在线播放 | 日本aaaa特级毛片 | 1717she国产精品免费视频 | 2021国产精品自在拍在线播放 |