国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:101日期:2023-11-20 19:20:10
PL/SQL 3.3以上的版本中,UTL_FILE包答應(yīng)用戶通過PL/SQL讀寫操作系統(tǒng)文件。如下: declarefile_handle UTL_FILE.FILE_TYPE;beginfile_handle := UTL_FILE.FOPEN('TMP', '文件名', 'w',[1-32767]); ;--四個(gè)參數(shù):目錄,文件名,打開方式,最大行數(shù)(默認(rèn)為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()過程用來以指定格式把文本寫入一個(gè)文件Put_Line()過程把一個(gè)指定的字符串寫入文件并在文件中開始新的一行9i中函數(shù)說明: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 /. 一個(gè)使用文件的測(cè)試1、用sys用戶登錄到數(shù)據(jù)庫(ora9i):conn sys/orcl@eai01 as sysdba2、在sqlplus中運(yùn)行create or replace directory TMP as 'd:testtmp'; 在sqlplus中運(yùn)行g(shù)rant read on directory TMP to public3、在scott用戶下建立存儲(chǔ)過程如: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中運(yùn)行set serveroutput on5、exec pReadFileTest('TMP','A.TXT','R')6、正常輸出小結(jié):在9i中可以不在init.ora中增加utl_file_dir目錄,而是在sys用戶下創(chuàng)建一個(gè)directory目錄(實(shí)際上是在sys用戶下的dir$表中增加一個(gè)對(duì)應(yīng)的OS_PATH),然后將對(duì)該directory對(duì)象的讀/寫操作的權(quán)限grant給public。
標(biāo)簽: Oracle 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 久久99亚洲精品久久99 | 国产片18在线观看 | 一级一黄在线观看视频免费 | 韩国一级片视频 | 免费高清特级毛片 | 亚洲欧美日韩中文字幕在线一 | 国产精品1区 2区 3区 | 三级黄色在线播放 | 一区二区中文字幕在线观看 | 日本高清视频免费在线观看 | 国产手机在线国内精品 | 美女网站视频黄色 | 久久精品成人国产午夜 | 草草免费观看视频在线 | 国产极品一区 | 欧美在线日韩在线 | 99免费在线 | 免费看一片| 国产成人在线网址 | 欧美扣逼视频 | 国产第2页 | 国产精品九九免费视频 | 成年人在线网站 | 看毛片的网址 | 国产精品久久久久久福利漫画 | 亚洲视频中文 | 99精品视频一区在线视频免费观看 | 欧美另类在线视频 | 欧美一级片播放 | 欧美ⅹxxxx视频 | 一级特黄aa大片欧美网站 | 中文字幕一级片 | 国产日韩欧美一区二区三区在线 | 国产精品视频久久久久久 | 在线一区视频 | 日本三级香港三级人妇gg在线 | 亚洲精品久久久久影院 | 国产精品久久影院 | 青青青青爽视频在线播放 | 娇小性色xxxxx中文 | 免费看美女无遮掩的软件 |