通过一个例子给大家介绍一下在Oracle中使用大对象的方法。在这个例子中,目的是要把一个jpeg图像装入Oracle,并且用C++Builder显示出来。如果使用bmp图像,则处理的过程更简单一些,这里就不再鳌述了。
例子:
1. 创建一个表picture
create table picture
(
picture_name varchar2(30),
picture_blob blob,
picture_locator bfile
);
2. 创建一个目录,需要有DBA权限,用于指向在操作系统中的某个目录
create directory picture_dir as 'd:\blob_test';
假设在d:\blob_test目录下存放有pic.jpg、pic.bmp、pic.doc等文件
3. 插入一条记录,注意blob对象需要初始化为空对象,对于Blob类型的大对象必须用Empty_blob()函数。
insert into picture (picture_name,picture_blob,picture_locator )
values(
'pic1',empty_blob(),bfilename('PICTURE_DIR','PIC.JPG'));
4. 将picture_locator所指向的图形文件导入数据库的picture表中:
declare
l_pic_locator bfile;
l_pic_blob blob;
l_dir varchar2(200);
l_filename varchar2(200);
BEGIN
select picture_locator,picture_blob into l_pic_locator,l_pic_blob from picture where name='pic1';
-- 1。判断文件是否存在
IF DBMS_LOB.FILEEXISTS(l_pic_locator)=1 then
dbms_output.put_line('!!! The file exists!');
-- 2. 判断文件是否已被打开
if dbms_lob.fileisopen(l_pic_locator)=0 THEN
DBMS_OUTPUT.PUT_LINE(' THE FILE IS NOT OPEN, TO OPEN THE FILE...');
-- 3. 打开文件
DBMS_LOB.FILEOPEN(l_pic_locator);
DBMS_OUTPUT.PUT_LINE('!!! THE FILE IS OPENED!');
-- 4. 可以获得关于文件的一些信息,比如文件名,大小等
dbms_output.put_line('The Length of the file is:'||to_char(dbms_lob.getlength(l_pic_locator)));
dbms_lob.filegetname(l_pic_locator,l_dir,l_filename);
DBMS_OUTPUT.PUT_LINE('The opened file name is :'||l_dir||'\'||l_filename);
-- 5. 将外部jpeg文件装入Blob字段
DBMS_LOB.LOADFROMFILE(l_pic_blob,l_pic_locator,dbms_lob.getlength(l_pic_locator),1,1);
dbms_output.put_line('The file is loaded into database!');
END IF;
DBMS_OUTPUT.PUT_LINE('To close the file');
--6. 每一个fileopen必须有一个fileclose与之对应,所以关闭文件
IF DBMS_LOB.FILEISOPEN(l_pic_locator)=1 THEN
DBMS_LOB.FILECLOSE(l_pic_locator);
DBMS_OUTPUT.PUT_LINE('The file is closed!');
END IF;
END IF;
-- 7. 还必须在exception中保证文件关闭文件
exception
when others then
IF DBMS_LOB.FILEISOPEN(L_PIC)=1 THEN
DBMS_LOB.FILECLOSE(L_PIC);
DBMS_OUTPUT.PUT_LINE('An exception happens,the file is closed!');
else
dbms_output.put_line('An exception happens!') ;
end if;
END;
-------------------------------------------------
----------------------在C++Builder中使用从数据库中取得刚才创建的数据库中的图像------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
ADOQuery1->Close();
ADOQuery1->SQL->Clear()
- 2005-04-29Oracle数据库的启动和关闭方式小结
- 2005-04-29windows优化系统后oracle9i本地连接失败
- 2007-07-30分享Oracle9i中建立自增字段的最新办法
- 2005-08-24ORACLE常用傻瓜问题1000问(之五)
- 2004-04-23在Oracle中实现数据库的复制
- 2005-04-29Oracle9i初始化参数中文说明9
- 2004-10-16Oracle 10gas 之 perfermence tunning 初步
- 2005-04-29Oracle经验技巧集
- 2005-04-29使用Windows工具管理Nt上的Oracle数据库
- 2006-12-13Oracle数据库的安全策略
热点搜索
热点文章






