doumouyi4039 2018-09-20 14:48
浏览 84

处理绑定变量Oracle / PHP中的错误

I am trying to output the error message if the query had an error, here's my code:

class app {

    private $db;
    private $con;
    private $err;
    ...

public function addNewRelative($parentId, $name, $relationCode, $relation, $phone, $email) {

    $sql = "BEGIN XXDM_DSQUARE_PKG.CREATE_CONTACTS(
                :P_SUBJECT_PARTY_ID,
                :P_OBJECT_PARTY_NAME',
                :P_RELATIONSHIP_CODE,
                :P_RELATIONSHIP_TYPE,
                :P_MOBILE_NUMBER,
                :P_EMAIL_ADDRESS,
                :X_ERROR_MSG
            ); END;";            

    //Statement does not change
    $stmt = oci_parse($this->con, $sql);

    oci_bind_by_name($stmt, ':P_SUBJECT_PARTY_ID', $parentId);
    oci_bind_by_name($stmt, ':P_OBJECT_PARTY_NAME', $name);
    oci_bind_by_name($stmt, ':P_RELATIONSHIP_CODE', $relationCode);
    oci_bind_by_name($stmt, ':P_RELATIONSHIP_TYPE', $relation);
    oci_bind_by_name($stmt, ':P_MOBILE_NUMBER', $phone);
    oci_bind_by_name($stmt, ':P_EMAIL_ADDRESS', $email);
    oci_bind_by_name($stmt, ':X_ERROR_MSG', $this->err);

    // Execute the statement as in your first try
    if (oci_execute($stmt)) {
        return json_encode(["response"=>1]);
    } else {
        return json_encode(["response"=>0]);
    }
}

But I get the following error:

Warning: oci_execute(): ORA-06550: line 8, column 6: PLS-00363: expression '<null>' cannot be used as an assignment target ORA-06550: line 1, column 7: PL/SQL: Statement ignored in D:\Server\wamp\www\dmg-dsquares-bk\app.php on line 94

The problem is with ‘X_ERROR_MSG’ parameter, as it’s OUT parameter, and I don’t know how to bind it.

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 python的qt5界面
    • ¥15 无线电能传输系统MATLAB仿真问题
    • ¥50 如何用脚本实现输入法的热键设置
    • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
    • ¥30 深度学习,前后端连接
    • ¥15 孟德尔随机化结果不一致
    • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
    • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
    • ¥15 谁有desed数据集呀
    • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100