计算机教程

当前位置:3522.com > 计算机教程 > 【3522.com】PDO取Oracle lob大字段,当数据量太大无

【3522.com】PDO取Oracle lob大字段,当数据量太大无

来源:http://www.4sports-uk.com 作者:3522.com 时间:2020-05-08 23:22

首先,创建一个存储过程 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_3522.com,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的资料网上还是比较少的,能解决问题的就更不多了,发出来跟大家分享一下,肯定还有其他比较好的解决办法,欢迎跟大家一起探讨。

本文由3522.com发布于计算机教程,转载请注明出处:【3522.com】PDO取Oracle lob大字段,当数据量太大无

关键词: 3522.com