存储过程拼接了两个sql,如何执行;
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了存储过程拼接了两个sql,如何执行;相关的知识,希望对你有一定的参考价值。
create or replace procedure DELETE_THOROGH_INFO(v_tableName in varchar2, v_pkKey in varchar2, v_pkValue IN varchar2)
is
v_sql1 varchar2(200);
v_sql2 varchar2(200);
begin
v_sql1 :='DELETE FROM cfg_resource_log WHERE pk_col_value = '|| v_pkValue;
v_sql2 :='DELETE FROM ' ||v_tableName||' WHERE '||v_pkKey||'='||v_pkValue;
execute immediate v_sql1 ;
execute immediate v_sql2 ;
commit;
end DELETE_THOROGH_INFO;
prepare stml from v_sql1;
execute stml ;这样的语句来动态执行。 参考技术C sqlplus中:
exec DELETE_THOROGH_INFO('参数', '参数', '参数');
函数、过程中:
DELETE_THOROGH_INFO('参数', '参数', '参数');
PL_sql如何执行oracle存储过程
create or replace procedure area
begin
select * from ods_area;
end
execute area;--执行
1.select * from ods_area; 不能直接在pl/sql 中作为语句执行。
应该用 select 字段 into plsql变量 from 表名;
的形式来获取表中的数据,保存到plsql变量中。
2. 存储过程的语法格式为:
create or replace procedure area
is
--变量声明;
begin
--过程主体;
end area;
3. 如果存储过程代码无误,可以通过 "/" 来执行代码,编译存储过程。
4.通过exec 或 execute 来调用编译后的存储过程。
例如:
-- 创建procedure:
create or replace procedure area
is
num number ;
v_areaRecord dual%ROWTYPE;
begin
--例子1
select * into v_areaRecord from dual;
--例子2
select 12345 into num from dual;
end area;
/
-- 通过 / 执行;
--调用
exec area;本回答被提问者和网友采纳 参考技术B PLSQL Developer里面直接就有撒,用法如下:
declare
-- Non-scalar parameters require additional processing
env sys.odcienv;
begin
-- Call the procedure
sys.odcienvdump(env => env);
end; 参考技术C 在sqlplus中执行方法如下
1.(重要)在sqlplus中执行如下命令(只有这样才可以看到输出结果):
set serverout on;
2.创建
3.执行(1,2顺序可以调换)
在plsql developer中就简单了,可以在左侧列表中找到procedure,找到相应存储过程,右键,。。。等等方法
以上是关于存储过程拼接了两个sql,如何执行;的主要内容,如果未能解决你的问题,请参考以下文章
Oracle [存储过程] 执行动态拼接SQL语句并返回结果??