插入示例 創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括瀏陽網(wǎng)站建設(shè)、瀏陽網(wǎng)站制作、瀏陽網(wǎng)頁制作以及瀏陽網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,瀏陽網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到瀏陽省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任! 1. 利用存儲(chǔ)過程進(jìn)行插入數(shù)據(jù) -- 創(chuàng)建存儲(chǔ)圖片的表 CREATE TABLE IMAGE_LOB ( T_ID VARCHAR2 ( 5 ) NOT NULL , T_IMAGE BLOB NOT NULL ); -- 創(chuàng)建存儲(chǔ)圖片的目錄,我這里在本地 C 盤 CREATE OR REPLACE DIRECTORY IMAGES AS 'C:\' ; -- 通過存儲(chǔ)過程來實(shí)現(xiàn)插入 CREATE OR REPLACE PROCEDURE IMG_INSERT ( TID VARCHAR2 , FILENAME VARCHAR2 ) AS F_LOB BFILE ; -- 文件類型 B_LOB BLOB ; BEGIN -- 插入空的 blob : EMPTY_BLOB () INSERT INTO IMAGE_LOB ( T_ID , T_IMAGE ) VALUES ( TID , EMPTY_BLOB ()) RETURN T_IMAGE INTO B_LOB ; -- 獲取指定目錄下的文件 F_LOB:= BFILENAME ( 'IMAGES' , FILENAME ); -- 以只讀的方式打開文件 DBMS_LOB . FILEOPEN ( F_LOB , DBMS_LOB . FILE_READONLY ); -- 傳遞對(duì)象 DBMS_LOB . LOADFROMFILE ( B_LOB , F_LOB , DBMS_LOB . GETLENGTH ( F_LOB )); -- 關(guān)閉原始文件 DBMS_LOB . FILECLOSE ( F_LOB ); COMMIT ; END ; / 2. 調(diào)用存儲(chǔ)過程插入圖片 call IMG_INSERT ( '1' , '1.jpg' ); 3. 驗(yàn)證結(jié)果 select * from IMAGE_LOB ;
修改示例 1. 通過過程進(jìn)行修改 declare l_bfile bfile ; l_blob blob ; begin update IMAGE_LOB set T_IMAGE=empty_blob () where T_ID=1 return T_IMAGE into l_blob ; -- 圖片路徑還在 C 盤,通過系統(tǒng)表 SELECT * FROM dba_directories; 查詢 l_bfile:=bfilename ( 'IMAGES' , '2.jpg' ); -- 以只讀的方式打開文件 dbms_lob . open ( l_bfile , dbms_lob . file_readonly ); -- 傳遞對(duì)象 dbms_lob . loadfromfile ( l_blob , l_bfile , dbms_lob . getlength ( l_bfile )); -- 關(guān)閉原始文件 dbms_lob . close ( l_bfile ); commit ; end ; / 2. 驗(yàn)證結(jié)果 select * from IMAGE_LOB ; |