主页 > 知识库 > PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法

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

热门标签:淮安自动外呼系统开发 语音电话机器人营销方案 修改高德地图标注 百变地图标注 广州市400电话办理 宜宾外呼系统厂家 南通防封外呼系统运营商 地图标注原件 语音电话机器人缺点
首先,创建一个存储过程 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的资料网上还是比较少的,能解决问题的就更不多了,发出来跟大家分享一下,肯定还有其他比较好的解决办法,欢迎跟大家一起探讨。
您可能感兴趣的文章:
  • Oracle 12c新特性之如何检测有用的多列统计信息详解
  • Oracle 11g收集多列统计信息详解
  • Oracle Translate 统计字符出现的次数示例代码
  • Oracle数据库按时间进行分组统计数据的方法
  • oracle表空间中空表统计方法示例介绍
  • oracle数据库下统计专营店的男女数量的语句
  • Oracle 统计用户下表的数据量实现脚本

标签:池州 股票投资 聊城 襄阳 南平 通化 南平 嘉峪关

巨人网络通讯声明:本文标题《PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法》,本文关键词  PDO,取,Oracle,lob,大,字段,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法》相关的同类信息!
  • 本页收集关于PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章