我已经将codeigniter dbdriver设置为“ oci8”。
作为参考,这是我的存储过程。这只是我的示例存储过程。
CREATE OR REPLACE STORED PROCEDURE sp_sample(
in_id IN VARCHAR2,
out_code OUT varchar,
out_desc OUT varchar) IS
var_result VARCHAR2(100);
CURSOR GetStatus (my_id IN NUMBER) IS
SELECT status
FROM tbl_sample
WHERE id= my_id;
BEGIN
OPEN GetStatus(in_id);
LOOP
FETCH GetStatus into var_result;
EXIT WHEN GetStatus%NOTFOUND;
END LOOP;
CLOSE GetStatus;
IF(result != 'A')
UPDATE tbl_sample SET status = 'A'
WHERE id = in_id;
COMMIT;
out_code := '00';
out_desc := 'Success';
ELSE
out_code := '01';
out_desc := 'Already active';
END IF;
END sp_sample;
这就是我如何在codeigniter中调用存储的proc:
$id = '10';
$params = array($id);
$result = $this->db->query("CALL sp_sample(?, @out_code, @out_desc)", $params);
exit($result);
然后我收到此错误消息:
Query error: ORA-00936: missing expression - Invalid query: CALL sp_sample('10', @out_code, @out_code)
我现在的问题是如何使用codeigniter调用oracle存储过程?如何正确绑定参数?
谢谢, 欧文