微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从P / L SQL脚本Oracle中使用“调用”功能的调用过程

如何解决从P / L SQL脚本Oracle中使用“调用”功能的调用过程

我无法在oracle数据库中运行此简单的if / then语句。 (我认为它是10.x,但不确定,这似乎是我的sql技能的问题,而不是数据库版本)。

您能帮我弄清楚如何运行此简单过程-email_table_copy()-仅在表中包含数据时发送表的csv副本吗?

我必须在email_table_copy过程中使用“呼叫”,看来这是问题所在。

非常感谢您的帮助。

DECLARE
    ncount   NUMBER(10);
    v_sql    LONG;
BEGIN
    SELECT
        COUNT(person_id)
    INTO ncount
    FROM
        test_conditional;

    IF ( ncount > 0 ) THEN
        v_sql := 'call email_table_function(''owner'',''test_conditional'',''csv'',''tyler.hahn@wpr.org''
);';
        EXECUTE IMMEDIATE v_sql; 
    END IF;

END;

解决方法

只需从您的;中删除v_sql

DECLARE
    ncount   NUMBER(10);
    v_sql    LONG;
BEGIN
    SELECT
        COUNT(person_id)
    INTO ncount
    FROM
        test_conditional;

    IF ( ncount > 0 ) THEN
        v_sql := q'[
           call email_table_function('owner','test_conditional','csv','tyler.hahn@wpr.org')
        ]';
        EXECUTE IMMEDIATE v_sql; 
    END IF;

END;

正如您所看到的,我对您的文字进行了一些修改,使其q-literal更具可读性。

简单的例子:

begin
  execute immediate q'[
     call dbms_output.put_line('Test string')
  ]';
end;
/

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。