【转】ORACLE BLOB BFILE 文件的录入及读取

来源:互联网 发布:营销分析报告数据图表 编辑:程序博客网 时间:2024/06/06 02:55

如果你接触过mysql的话一定对mysql的text和blob不会陌生,在mysql中是直接操作text和blob的。但是在oracle中,它把lob做为一种特殊的字段,不能直接进行操作--比如不能直接插入到lob字段中,也不能用like查询等等。   

  这里是我保存的一篇这方面的文章,原文搬过来,由于保存的时候只是取了一部分,没头没尾的,所以没法找到原来的出处。   
    
  不能直接用INSERT语句向LOB字段中插入值。一般情况下,有如下的几步:     
  1   先分析一个INSERT语句,返回一个LOB的描述符     
  2   用OCI函数生成一个本地的LOB对象     
  3   将LOB对象绑定到LOB描述符上     
  4   执行INSERT语句     
  5   给LOB对象赋值     
  6   释放LOB对象和SQL语句句柄     
    
  下面的这个例子是把用户上传的图片文件存放到BLOB(或BFILE中,操作稍有不同)中。     
  首先要建一个表,结构如下:  

  CREATE   TABLE   PICTURES   (     
  ID   NUMBER,     
  DESCRIPTION   VARCHAR2(100),     
  MIME   VARCHAR2(128),     
  PICTURE   BLOB     
  );  

  如果要实现ID的自动增加,再建一个SEQUENCE:     
  CREATE   SEQUENCE   PIC_SEQ;     
    
  然后是用来处理数据的PHP程序代码。     
    
    
  还有一个要注意的地方:LOB字段的值最少要1个字符,所以在save()或savefile()之前,要确保值不能为空。否则,Oracle会出错。     
    
  取出     
    
  对一个LOB中取出数据,有两种办法。一是生成一个LOB对象,然后绑定到一条SELECT语句返回的定位符上,再用LOB对象的load()方法取出数据;二是直接用PHP的OCIFetch***函数。第一种方法比第二种方法要麻烦得多,所以我直接说说第二种方法。     
    
  还是用上面的表。     
    
 
    
  这个程序用来显示放在LOB中的数据(图片)。调用方法(假设脚本名是getpicture.php):     
  <IMG   SRC="getpicture.php?pictureid=99"   ALT="放在Oracle   LOB中的图片">     
    
  查询     
    
  前面已经提了下,对于Oracle的LOB字段是不能用LIKE进行匹配的。怎么办呢?其实并不复杂,Oracle有一个匿名的程序包,叫DBMS_LOB,里面有所有的操作LOB所需的过程。     
    
  假设有象这样一个表:     
  CREATE   TABLE   ARTICLES   (     
  ID   NUMBER,     
  TITLE   VARCHAR2(100),     
  CONTENT   CLOB     
  );     
    
  文章的内容放在CONTENT字段中。     
    
  现在我们要找出所以内容中包含"PHP中文用户"的文章,可以这么来做:     
    
  

 

-----------------------------------------------------------------------------------------------------------------------------------------------------

 

这是我的测试成功结果,供大家参考!   

 

 

 
原创粉丝点击