• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法
    首先,创建一个存储过程 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 统计用户下表的数据量实现脚本
    上一篇:Oracle9i 动态SGA,PGA特性探索
    下一篇:ORACLE 数据库RMAN备份恢复
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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