手机
当前位置:查字典教程网 >编程开发 >Oracle教程 >PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法
PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法
摘要:首先,创建一个存储过程get_clob:t_name:要查询的表名;f_name:要查询的字段名;u_id:表的主键,查询条件;l_pos:...

首先,创建一个存储过程 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大字段,当数据量太大无法取出的问题的解决办法】相关文章:

Oracle数据库的备份及恢复策略研究

Oracle监听器服务不能启动的7步解决法

oracle 11.1.0.7版本也会出现access$表丢失导致数据库无法启动

Oracle 数据库导出(exp)导入(imp)说明

修改计算机名或IP后Oracle10g无法启动服务的解决办法

Oracle数据库TNS常见错误的解决办法

在Oracle网络结构解决连接问题

Oracle数据库TNS常见错误的解决方法汇总

Oracle存储过程之数据库中获取数据实例

Oracle教程 误添加数据文件删除方法

精品推荐
分类导航