十一月上旬更新速递丨 数据与 AI 技术深耕、场景应用拓展与开发进阶实战

秋意正浓时,智能征程不止步!十一月上旬欢度14周年,聚焦数据与AI领域的知识深化、场景化应用落地、技术开发进阶,从理论到实战的全链路能力提升!

一、14周年活动

《14周年·探索乐章 | 寻藏宝图,挖掘社区金矿(已更新1-9关卡)开启一场知识寻宝探险之旅,重温与思迈特并肩成长的温暖时光!

《14周年·温情乐章|写下专属祝福,传递温暖情谊为思迈特14周年注入一份温度,也为这份同行之谊添上一抹亮色!

《14周年·荣誉乐章 | 星光致敬,表彰贡献榜样→回馈大家对社区生态的倾心建设,感谢每一位共建者的热忱与坚守!

二、场景应用

《构建“战略-业务-数据”三层指标体系(体系篇)》→“战略-业务-数据”三层指标体系是AIChat听懂的坚实的底层支撑。

三、术经验分享

《【专家分享】用Smartbi快速搞定数据刷新,老板看了都说好!》→掌握了数据刷新“提速”秘籍:告别滞后,让数据“实时在线”!

《【专家分享】数据排序的“权力游戏”:优先级规则决定谁先谁后》→提供了数据排序指南:破解多指令冲突,明确 “谁先生效”!

四、二次开发视频

扩展包开发前端改造了解前端改造的基本方法与实现流程、如何在Smartbi扩展包中修改CSS样式、扩展JS组件。

、任务持续上线

《【场景实战】数据驱动决策全流程实战:dws层数据处理》→深入数据决策,提升数据整合与维度设计能力,挑战成功即可获得麦豆奖励!

《【AIChat入门闯关计划】-随机掉落小测试》→快速检验AIChat知识漏洞,巩固核心概念。接受挑战即可获得麦豆奖励。

为进一步提升认证服务的质量与体验,我们对认证业务进行全面优化升级。更多详情请看Smartbi认证考试优化升级公告

麦粉社区
>
帖子详情

Oracle在没有结果集返回的存储过程该怎么调用

安装指导 发表于 2024-9-13 01:29
发表于 2024-9-13 01:29:49
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2024-9-13 01:29:50
在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”任务来调用存储过程,而不是通过数据集。
回复

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1回帖数 0关注人数 1604浏览人数
最后回复于:2024-9-13 07:52
快速回复 返回顶部 返回列表