栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在oracle存储过程中创建和执行动态查询?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在oracle存储过程中创建和执行动态查询?

您在这里遇到一些问题,包括:

  • IN_DATE
    被声明为日期,因此您无需将其传递给
    TO_DATE()
  • 您只需要一个游标循环;如果
    employee_id
    出于某种原因要一起处理所有更新,则可以添加一个
    order by
    子句。
  • 您根本不需要动态SQL。您可以将游标中的值用作静态SQL更新的一部分。

因此,具有单个循环的简单版本可能类似于:

CREATE OR REPLACe PROCEDURE sp_run_employee_updates (p_date IN DATE) IS    CURSOR c_updates IS        SELECT *        FROM bi_employee_update        WHERe effective_date = p_date        AND executed = 'N'         AND activity_id = '0'        FOR UPDATE;     BEGIN    -- loop around all pending records    FOR r_update IN c_updates LOOP        -- apply this update to the bi_employee record        UPDATE bi_employee        SET col1 = r_update.col1, col2 = r_update.col2        WHERe emp_id = r_update.employee_id;        -- mark this update as executed        UPDATE bi_employee_update        SET executed = 'Y'        WHERe CURRENT OF c_updates;    END LOOP;END sp_run_employee_updates;

这是使用

for update
and
where currentof
构造来锁定您正在使用的行并简化更新;请参阅此处的文档。

值得一提的是,如果其中一个

effective_date
p_date
一个没有时间部分,它们将不匹配。这不太可能
p_date
,但更难猜测
effective_date
。如果确实如此,那么您要么需要
trunc()
它,要么用它
between
寻找一段时间。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/398484.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号