正 文

用PHP操纵Oracle的LOB类型的数据


www.7dspace.com  更新日期:2006-2-1 8:27:19  七度空间


  取出

  对一个LOB中取出数据,有两种办法。一是生成一个LOB对象,然后绑定到一条SELECT语句返回的定位符上,再用LOB对象的load()方法取出数据;二是直接用PHP的OCIFetch***函数。第一种方法比第二种方法要麻烦得多,所以我直接说说第二种方法。

  还是用上面的表。

<?php
 $conn = OCILogon($user, $password, $SID);
 $stmt = OCIParse($conn,"SELECT * FROM PICTURES WHERE ID=$pictureid");
 OCIExecute($stmt);

 //秘密就在PCIFetchInfo的第三个参数上:OCI_RETURN_LOBS。第三个参数是FETCH的模式,如果OCI_RETURN_LOBS,就直接把LOB的值放到结果数组中,而不是LOB定位符,也就不用LOB对象的load()方法了。

 if (OCIFetchInto($stmt, $result, OCI_ASSOC+OCI_RETURN_LOBS))
 {
  echo "Content-type: " . StripSlashes($result[MIME]);
  echo StripSlashes($result[PICTURE]);
 }
 OCIFreeStatement($stmt);
 OCILogoff($conn);
?>

  这个程序用来显示放在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中文用户"的文章,可以这么来做:

<?php
 $conn = OCILogon($user, $password, $SID);

 //WHERE子句中用了DBMS_LOB.INSTR过程。它有四个参数,前面两个分别表示LOB的定位符(可以直接用字段表示)和要查找的字符串;后面两个分别表示开始的偏移量和出现的次数。要注意的是必须判断它的返回值,也就是要大于0。

 $stmt = OCIParse($conn,"SELECT * FROM ARTICLES WHERE DBMS_LOB.INSTR(CONTENT, 'PHP中文用户', 1, 1) > 0");
 OCIExecute($stmt);
 if (OCIFetchInto($stmt, $result, OCI_ASSOC+OCI_RETURN_LOBS))
 {
  ...
 }
 OCIFreeStatement($stmt);
 OCILogoff($conn);
?>

  Oracle还提供了许多用来操作LOB数据的过程,如LENGTH, SUBSTR等等。至于它们的详细用法,可以考虑Oracle的开发手册。

  关于对Oracle数据库中的LOB类型的数据的操作,就说这么多了。由于我接触Oracle时间不长,本文中可能还会有错误,欢迎大家批评指正。

2页,页码:[1] [2] 

上一篇:Delphi中用TListView显示数据库数据
下一篇:用VC实现PC并行端口数字信息的输入/输出
标题:用PHP操纵Oracle的LOB类型的数据 作者: 来源:IT计算机教程
收藏此页】【打印】【关闭
站 内 搜 索
 

热 点 导 读
特 别 推 荐