问题描述
我无法在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;
/