用PHP操纵Oracle的LOB类型的数据(2)_PHP教程

编辑Tag赚U币
教程Tag:暂无Tag,欢迎添加,赚取U币!

推荐:童虎:人人皆可做插件 Discuz! 插件开发实例讲解
作者简介:童虎,Discuz!论坛程序研发经理,负责Discuz!论坛程序研发团队的管理工作,曾是Discuz!早期插件作者,担任过Freediscuz插件区版主。 曾开发过社区宠物、社区监狱、社区虚拟形象等多个

 //释放LOB对象

 OCIFreeDesc($lob);
 OCIFreeStatement($stmt);
 OCILogoff($conn);
?>

  还有一个要注意的地方:LOB字段的值最少要1个字符,所以在save()或savefile()之前,要确保值不能为空。否则,Oracle会出错。

  取出

  对一个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时间不长,本文中可能还会有错误,欢迎大家批评指正。

分享:PHP技术进阶 PHP SOCKET 技术研究
今天试着写一个 PHP 与 C 语言通过socket通讯的程序,看过PHP手册,发现有好几种方式可以建立socket 客户端. 1、通过 fsockopen() 建立socket连接,然后用 用fputs() 发送消息,用 fgets() 接

共2页上一页12下一页
来源:模板无忧//所属分类:PHP教程/更新时间:2008-08-22
相关PHP教程