| 在Smartbi中调用Oracle存储过程时,如果存储过程没有返回结果集(即没有使用游标作为输出参数),您仍然可以通过以下方式在数据集中调用该存储过程。 
 方法一:使用动态SQL
 创建一个包含动态SQL的存储过程:
 
 在Oracle数据库中创建一个存储过程,该存储过程执行一些操作但不返回结果集。例如:
 SQL
 CREATE OR REPLACE PROCEDURE "FOODMART"."SP_NO_RESULT" (I_ID IN NUMBER) AS
 BEGIN
 -- 执行一些操作,例如更新数据
 UPDATE account SET account_name = 'Updated' WHERE account_id = I_ID;
 END;
 在Smartbi中创建一个数据集:
 
 在Smartbi中创建一个新的数据集,选择“原生SQL数据集”。
 在SQL编辑器中编写以下SQL语句:
 SQL
 BEGIN
 "FOODMART"."SP_NO_RESULT"(:param_id);
 END;
 在这个例子中,param_id 是您在Smartbi中定义的参数,用于传递给存储过程。
 保存并运行数据集:
 
 保存数据集并运行它。在运行时,输入参数 param_id 的值,系统将调用存储过程并执行相应的操作。
 方法二:使用SELECT语句包装
 创建一个返回结果集的存储过程:
 
 如果存储过程没有返回结果集,您可以创建一个新的存储过程,该存储过程调用原始存储过程并返回一个虚拟的结果集。例如:
 SQL
 CREATE OR REPLACE PROCEDURE "FOODMART"."SP_WRAPPER" (I_ID IN NUMBER, O_RESULT OUT VARCHAR2) AS
 BEGIN
 -- 调用原始存储过程
 "FOODMART"."SP_NO_RESULT"(I_ID);
 -- 返回一个虚拟的结果
 O_RESULT := 'Operation Completed';
 END;
 在Smartbi中创建一个数据集:
 
 在Smartbi中创建一个新的数据集,选择“原生SQL数据集”。
 在SQL编辑器中编写以下SQL语句:
 SQL
 DECLARE
 v_result VARCHAR2(100);
 BEGIN
 "FOODMART"."SP_WRAPPER"(:param_id, v_result);
 -- 返回结果集
 SELECT v_result AS result FROM dual;
 END;
 在这个例子中,param_id 是您在Smartbi中定义的参数,用于传递给存储过程。
 保存并运行数据集:
 
 保存数据集并运行它。在运行时,输入参数 param_id 的值,系统将调用存储过程并返回虚拟的结果集。
 注意事项
 在Smartbi中,数据集必须有返回结果集,因此即使存储过程没有返回结果集,您也需要通过上述方法返回一个虚拟的结果集。
 如果存储过程执行的操作不需要返回结果集,您可以在Smartbi中创建一个“执行SQL”任务来调用存储过程,而不是通过数据集。
 |