国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

教你快速掌握Oracle數據庫中的 bfile

瀏覽:81日期:2023-11-26 15:33:54
具體步驟如下:1.先在Oracle數據庫中下面我們建立一個目錄別名,用于將文件定位指針映射到文件系統:create DirectorY 'tmpdir' AS '/tmp';tmpdir表示邏輯目錄名,'/tmp'是實際目錄。 注重該目錄oracle應該有讀權限 然后根據需要授權。GRANT READ ON DIRECTORY bfile_dir1 TO scott;建立一個含有bfile字段的表;create table bfiletest(id number(3), fname bfile);;建立一個含有BLOB字段的表create table bloBTest(id number(3),ablob blob);2.插入數據這里需要使用bfilename來進行bfile字段的insert 或者 update操作INSERT INTO bfiletest VALUES (1, BFILENAME ('tmpdir', 'tmptest'));bfilename的參數1是DIRECTORY名,參數2是文件名。注重:這一行中插入的是一個指向/tmp/tmptest的文件定位指針映射,不是文件本身。3.讀取bfile通過使用dbms_lob包進行可以對bfile讀入到blob/clob對象中操作(只讀)CREATE OR REPLACE PROCEDURE loadLOBFromBFILE_proc(TID IN NUMBER,rfilename in varchar2,rfiledir in varchar2,upmessage out varchar2) AS Dest_loc;;;;BLOB; Src_loc;;;;;BFILE;BEGIN INSERT INTO BLOBTEST(ID,ABLOB) VALUES(TID,EMPTY_BLOB()) RETURN ABLOB INTO DEST_LOC; Src_loc := BFILENAME(rfiledir,rfilename); /* 假如bfile文件實際存在 */ IF (DBMS_LOB.FILEEXISTS(Src_loc) != 0) THEN /* 打開bfile源文件 */; DBMS_LOB.OPEN(Src_loc, DBMS_LOB.LOB_READONLY); /* 打開目標blob: */; DBMS_LOB.OPEN(Dest_loc, DBMS_LOB.LOB_READWRITE); /*從文件中裝入 */ DBMS_LOB.LOADFROMFILE(Dest_loc, Src_loc,DBMS_LOB.GETLENGTH(Src_loc)); /* 記得關閉: */; DBMS_LOB.CLOSE(Dest_loc); DBMS_LOB.CLOSE(Src_loc); COMMIT; upmessage := '0'; END IF; EXCEPTION WHEN OTHERS THEN ROLLBACK; upmessage := '操作失敗'; END;(注釋:bfile字段實際的文件存儲在文件系統中,字段中存儲的是文件定位指針.bfile對oracle來說是只讀的,也不參與事務性控制和數據恢復)。
標簽: Oracle 數據庫
主站蜘蛛池模板: 扶余县| 小金县| 敦化市| 宝坻区| 福建省| 顺昌县| 阳新县| 柞水县| 平昌县| 吴川市| 石家庄市| 海淀区| 涟源市| 丽江市| 定州市| 汽车| 三门县| 南澳县| 汉中市| 同心县| 务川| 道孚县| 陆川县| 陈巴尔虎旗| 四会市| 通山县| 清原| 罗山县| 会宁县| 永善县| 浦东新区| 梁平县| 西安市| 海城市| 信宜市| 大邑县| 中江县| 绥宁县| 青田县| 昌平区| 炉霍县|