服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Oracle - PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法

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

2019-10-30 19:01Oracle教程网 Oracle

最近,做sns的项目,用PDO连接Oracle数据库,读取Clob字段,当数据量非常大的时候(上万个字符),返回空值,从网上也没有查到相关的资料。自己刻苦研究加上同事帮助,终于解决了。废话就不说了,下面把内容贴出来。

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

延伸 · 阅读

精彩推荐