php调用oracle存储过程,并获取结果集

浏览:278 发布日期:2021/04/23 分类:技术分享 关键字: oracle 存储过程 php tp6 tp5 结果集
$tns = "(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = {$datas['hostname']})(PORT = {$datas['hostport']})))(CONNECT_DATA =(SERVICE_NAME = {$datas['database']})))";
            $db = oci_connect($datas['username'], $datas['password'], $tns, 'UTF8');
            if (!$db) return false;
            //调用存储过程
            $batchNumber = time() . rand(1000, 9999);
            $stmt = oci_parse($db, "call {$datas['function_name']}(:batchNumber,:param,:code,:msg,:data)");
            //输入参数
            oci_bind_by_name($stmt, ":batchNumber", $batchNumber, 500);
            oci_bind_by_name($stmt, ":param", $param, 500);
            //输出参数
            oci_bind_by_name($stmt, ":code", $code, 32);
            oci_bind_by_name($stmt, ":msg", $msg, 200);
            oci_bind_by_name($stmt, ":data", $data, 200);
            oci_execute($stmt);
            return ['return_code' => $code, 'return_msg' => $msg, 'return_data' => $data];
一开始使用的pdo_oci 可以请求到存储过程 入参也正常 但是出参怎么也获取不到 最后在php官网看到 pdo_oci扩展最后一次更新时间是在2005年 可以说已经废弃了
解决方案:使用oci8链接oracle就正常了
最佳答案
评论( 相关
后面还有条评论,点击查看>>