佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > PDO取Oracle lob大字段,當(dāng)數(shù)據(jù)量太大無(wú)法取出的問(wèn)題的解決辦法

PDO取Oracle lob大字段,當(dāng)數(shù)據(jù)量太大無(wú)法取出的問(wèn)題的解決辦法

熱門標(biāo)簽:百度競(jìng)價(jià)排名 服務(wù)外包 呼叫中心市場(chǎng)需求 Linux服務(wù)器 AI電銷 鐵路電話系統(tǒng) 地方門戶網(wǎng)站 網(wǎng)站排名優(yōu)化
首先,創(chuàng)建一個(gè)存儲(chǔ)過(guò)程 get_clob:
t_name:要查詢的表名;f_name:要查詢的字段名;u_id:表的主鍵,查詢條件;l_pos:截取的開始位置; l_amount :截取長(zhǎng)度;
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字段長(zhǎng)度
$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;//截取長(zhǎng)度
$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;
以上就是完整的解決辦法,這個(gè)方法不是俺的首創(chuàng),做過(guò)pb項(xiàng)目的人大多數(shù)應(yīng)該比較熟悉這種操作。
php操作Oracle的資料網(wǎng)上還是比較少的,能解決問(wèn)題的就更不多了,發(fā)出來(lái)跟大家分享一下,肯定還有其他比較好的解決辦法,歡迎跟大家一起探討。
您可能感興趣的文章:
  • Oracle 12c新特性之如何檢測(cè)有用的多列統(tǒng)計(jì)信息詳解
  • Oracle 11g收集多列統(tǒng)計(jì)信息詳解
  • Oracle Translate 統(tǒng)計(jì)字符出現(xiàn)的次數(shù)示例代碼
  • Oracle數(shù)據(jù)庫(kù)按時(shí)間進(jìn)行分組統(tǒng)計(jì)數(shù)據(jù)的方法
  • oracle表空間中空表統(tǒng)計(jì)方法示例介紹
  • oracle數(shù)據(jù)庫(kù)下統(tǒng)計(jì)專營(yíng)店的男女?dāng)?shù)量的語(yǔ)句
  • Oracle 統(tǒng)計(jì)用戶下表的數(shù)據(jù)量實(shí)現(xiàn)腳本

標(biāo)簽:衡水 仙桃 湘潭 蘭州 湖南 崇左 黃山 銅川

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PDO取Oracle lob大字段,當(dāng)數(shù)據(jù)量太大無(wú)法取出的問(wèn)題的解決辦法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    辉县市| 元朗区| 河津市| 竹北市| 星座| 阿合奇县| 本溪市| 晋州市| 托里县| 巩义市| 宿松县| 新巴尔虎右旗| 竹溪县| 五常市| 资源县| 临洮县| 大丰市| 巴塘县| 穆棱市| 广东省| 绿春县| 西昌市| 连山| 阿拉尔市| 元氏县| 马公市| 高邑县| 会泽县| 麻江县| 绥江县| 定安县| 贵溪市| 米脂县| 舞阳县| 双辽市| 丹寨县| 车险| 翁源县| 皋兰县| 高密市| 陆良县|