Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何从OCI调用ORACLE函数?_C_Oracle_Oracle Call Interface - Fatal编程技术网

如何从OCI调用ORACLE函数?

如何从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),

我可以在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), (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的值

谢谢你的回答,托马斯,我照你说的做了,它是正确的。谢谢你的回答,托马斯,我照你说的做了,它是正确的。