网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.经典的Oracle图书推荐-之二.
.如何加密Oracle中的存储过程,从而.
.Oracle PL/SQL的第一次接触.
.Tomcat5.0.19与oracle8.1.7连接池.
.都是防火墙惹的祸--Oracle连接总.
.使用XMLTransform和XSL-FO格式化.
.ORACLE SGA 的分配.
.SQL Server 与Oracle的不同点(从.
.ORACLE Developer/2000 编程技巧.
.Oracle数据库中独一无二的Cache对.
.利用游标返回结果集的的例子(Or.
.postfix出现错误“fatal: unknow.
.ORACLE常用傻瓜问题1000问全集(.
.OMF方式手动创建数据库.
.使用ssh实现oracle数据库备份文件.
.多个数据库时 如何设置默认数据库.
.Oracle PL/SQL入门之慨述.
.在Oracle中返回多个结果集.
.上海Oracle OpenWorld大会纪事-0.
.Oracle 参数绑定性能实践.

怎样在Oracle中创建,维护图形大对象

发表日期:2008-2-9



  通过一个例子给大家介绍一下在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(); 
  ADOQuery1->SQL->Add(Memo1->Lines->Text); 
  ADOQuery1->Open(); 
   
  if (ADOQuery1->FieldByName("name")->AsString=="pic1") 
  DBImage1->DataField="PICTURE_BLOB"; 
  else 
  { 
   
  //1.创建用于存放Blob大对象的临时字段,并初始化为从数据库中取得的图形 
  TBlobField *pField = (TBlobField *)ADOQuery1->FieldByName("picture_blob"); 
   
  //2.创建一个BlobStream流,以流的形式读取图形数据 
  TADOBlobStream *pmem = new TADOBlobStream(pField,bmRead); 
   
  //3. 将流指针放在流的头部 
  pmem->Seek(0,soFromBeginning); 
   
  //4. 新建一个JPEG对象 
  TJPEGImage * jp = new TJPEGImage(); 
   
  //5. 将放在BlobStream流中的图形信息读入jpeg对象 
  jp->LoadFromStream(pmem); 
   
  //6. 将jpeg图像放在Image控件的picture组件的Graphic内,显示出来 
  Image1->Picture->Graphic=jp; 
   
  //7. 释放BlobStream流 
   
  delete pmem; 
   
  } 
   
  }
上一篇:RED HAT 7.3装Oracle8.1.7配置什么内核参数 人气:843
下一篇:Oracle10g for AIX5L安装过程 人气:666
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐