如何从OCI调用ORACLE函数?
我可以在C程序中通过OCI调用ORACLE存储过程,方法是为该命令构造SQL命令,下面是我代码中的一个简短片段:如何从OCI调用ORACLE函数?,c,oracle,oracle-call-interface,C,Oracle,Oracle Call Interface,我可以在C程序中通过OCI调用ORACLE存储过程,方法是为该命令构造SQL命令,下面是我代码中的一个简短片段: /* build sql statement calling stored procedure */ strcpy ( sql_stmt, "call get_tab_info(:x)" ); rc = OCIStmtPrepare(p_sql, p_err, sql_stmt, (ub4) strlen (sql_stmt),
/* build sql statement calling stored procedure */
strcpy ( sql_stmt, "call get_tab_info(:x)" );
rc = OCIStmtPrepare(p_sql, p_err, sql_stmt,
(ub4) strlen (sql_stmt), (ub4) OCI_NTV_SYNTAX, (ub4) OCI_DEFAULT);
但是如何在C程序中构造对具有以下签名的ORACLE函数的调用:
CREATE OR REPLACE FUNCTION get_seq_number (p_table_name IN VARCHAR2, p_seq_type IN VARCHAR2)
RETURN NUMBER IS
要在PL/SQL中调用函数,我将使用以下示例:
v_seq := get_seq_number(v_tabname, v_seqtype);
如何构造SQL字符数组SQL stmt以在我的C程序中调用ORACLE函数?您可以:
SELECT my_udf()
FROM dual
并按SELECT查询中的方式解析结果,或调用匿名块:
BEGIN
:test := my_udf();
END;
,并绑定:作为输出参数进行测试。您可以发出:
SELECT my_udf()
FROM dual
并按SELECT查询中的方式解析结果,或调用匿名块:
BEGIN
:test := my_udf();
END;
,并绑定:作为输出参数进行测试。按如下方式构造SQL语句
strcpy ( sql_stmt, "BEGIN :v_seq := get_seq_number(:v_tabname, :v_seqtype); END;" );
像以前一样准备你的陈述。按名称绑定变量,包括前面代码中的v_seq,并执行该语句。程序完成后,将正确设置:v_seq的值 按如下方式构造SQL语句
strcpy ( sql_stmt, "BEGIN :v_seq := get_seq_number(:v_tabname, :v_seqtype); END;" );
像以前一样准备你的陈述。按名称绑定变量,包括前面代码中的v_seq,并执行该语句。程序完成后,将正确设置:v_seq的值 谢谢你的回答,托马斯,我照你说的做了,它是正确的。谢谢你的回答,托马斯,我照你说的做了,它是正确的。