PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法

来源:asp之家 时间:2009-04-30 18:41:00 

首先,创建一个存储过程 get_clob:

t_name:要查询的表名;f_name:要查询的字段名;u_id:表的主键,查询条件;l_pos:截取的开始位置; l_amount :截取长度;

CREATE OR REPLACE PROCEDURE get_clob(t_name in varchar2, f_name in varchar, u_id in integer, l_pos in integer, l_amount in BINARY_INTEGER, ReturnValue out varchar2) is
rule_xml clob;
l_buffer varchar2(3999);
l_amount_ BINARY_INTEGER;
begin
execute immediate 'select ' ||f_name|| ' from ' ||t_name|| ' where id=:1' into rule_xml using u_id;
l_amount_:=l_amount;
DBMS_LOB.read(rule_xml, l_amount_, l_pos, l_buffer);
ReturnValue := l_buffer;
end get_clob;

然后是php的处理程序:

$content = "";
$num = 0;//clob字段长度
$stmt = $oracle->prepare("select length(content) as num from test where id = $id");
if ($stmt->execute()) { //zjh为查询的条件
$row = $stmt->fetch();
$num = $row['NUM'];
}
$start = 1;//初始化开始位置
$len = 2500;//截取长度
$t_name = 'test';//操作表名
$f_name = 'content';//需要查询的clob字段名
while ($start <= $num){
$ret='';
$sql = "begin get_clob(?,?,?,?,?,?); end;";
$stmt = $oracle->prepare($sql);
$stmt->bindParam(1, $t_name, PDO::PARAM_STR, 100);
$stmt->bindParam(2, $f_name, PDO::PARAM_STR, 100);
$stmt->bindParam(3, $id, PDO::PARAM_STR, 100);
$stmt->bindParam(4, $start, PDO::PARAM_STR, 100);
$stmt->bindParam(5, $len, PDO::PARAM_STR, 100);
$stmt->bindParam(6, $ret, PDO::PARAM_STR, 5000);
$stmt->execute();
$content .= $ret;
$start=$start+$len;
}
$oracle = null;

以上就是完整的解决办法,这个方法不是俺的首创,做过pb项目的人大多数应该比较熟悉这种操作。
php操作Oracle的资料网上还是比较少的,能解决问题的就更不多了,发出来跟大家分享一下,肯定还有其他比较好的解决办法,欢迎跟大家一起探讨。

标签:PDO,Oracle,lob
0
投稿

猜你喜欢

  • 朋友去一家游戏公司的机试题,被难住了

    2009-11-29 15:23:00
  • 远程连接access数据库的几个方法

    2008-10-21 21:16:00
  • SQL大讲堂:如何了解SQL的执行频率

    2009-09-05 09:40:00
  • Favicon图标小常识

    2010-04-01 12:01:00
  • 数据库技巧——MySQL十大优化技巧

    2011-01-31 16:44:00
  • ASP格式化日期的函数(输出13种样式)

    2011-07-12 20:22:00
  • try finally 妙用,防止内存泄漏

    2008-03-26 12:52:00
  • MenuEverywhere 程序图标设计

    2011-08-14 06:57:23
  • Discuz7 的提示效果如何实现

    2010-01-13 13:10:00
  • oracle 存储过程加密的方法

    2009-03-06 10:58:00
  • 制作Dreamweaver活动菜单条

    2008-10-03 20:59:00
  • javascript设计模式交流(二) Prototype Pattern

    2007-11-29 14:01:00
  • SQL SERVER 2005中的同步复制技术

    2009-01-05 13:44:00
  • SQLServer与服务器连接时出错的解决方案

    2009-06-28 14:35:00
  • 10条影响CSS渲染速度的写法与建议

    2008-09-09 22:02:00
  • sqlserver获取当前日期的最大时间值

    2011-09-30 11:44:50
  • SQL Server中如何优化磁带备份设备性能

    2009-01-07 14:23:00
  • XHTML1.0规范:您是否为img图片标签赋予alt属性

    2009-09-21 11:11:00
  • XML的语法、结构以及相关的一些技术

    2007-10-23 07:27:00
  • Javascript实现的鼠标经过时播放声音

    2010-05-18 20:03:00
  • asp之家 网络编程 m.aspxhome.com