使用存储过程实现oracle存图片的方法

本文介绍了如何使用Oracle存储过程来存储图片。首先创建存储图片的表和目录,然后通过存储过程将图片从本地文件系统加载到BLOB字段。同时,提供了一个Java BlobDAO类的示例,用于从数据库中读取并显示图片。
摘要由CSDN通过智能技术生成

oracle存图片是我们经常需要实现的功能,下面就教您一个使用存储过程实现oracle存图片的方法,如果您在oracle存图片方面遇到过问题,不妨一看。

要在oracle存图片 用blob类型,首先在数据库里建立:

--连接到管理员

 
  1. conn sys/tbsoft as sysdba; 

--为scott用户授权

 
  1. grant create any directory to scott; 

--回到scott用户

 
  1. conn scott/tiger; 

--创建存储图片的表

 
  1. CREATE TABLE IMAGE_LOB (T_ID VARCHAR2 (5) NOT NULL,T_IMAGE BLOB NOT NULL); 

--创建存储图片的目录

 
  1. CREATE OR REPLACE DIRECTORY IMAGES AS 'C:\picture'; 

--在c:下自己建一个叫picture的文件夹

 
  1. CREATE OR REPLACE PROCEDURE IMG_INSERT (TID VARCHAR2,FILENAME VARCHAR2) AS 

F_LOB BFILE;--文件类型

B_LOB BLOB;

 

 
  1. BEGIN     
  2. iNSERT INTO IMAGE_LOB (T_ID, T_IMAGE)     
  3. VALUES (TID,EMPTY_BLOB ()) RETURN T_IMAGE INTO B_LOB    

 

--插入空的blob

 
  1. F_LOB:= BFILENAME ('IMAGES', FILENAME); 

--获取指定目录下的文件

 
  1. DBMS_LOB.FILEOPEN(F_LOB, DBMS_LOB.FILE_READONLY); 

--以只读的方式打开文件

 
  1. DBMS_LOB.LOADFROMFILE (B_LOB, F_LOB,DBMS_LOB.GETLENGTH (F_LOB)); 

--传递对象

 
  1. DBMS_LOB.FILECLOSE (F_LOB); 

--关闭原始文件

 
  1. COMMIT;  
  2. END;  
  3. /  

--在C:\picture下放一张图片1.gif

--将该图片存入表

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值