oracle 存储过程sql语句

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle 存储过程sql语句相关的知识,希望对你有一定的参考价值。

现在我在一个存储过程里写了2条语句
如下:
delete from t1 where tid in (select tid from tableid );
delete from t2 where tid in(select tid from tableid);
update t3 set name='abc' where tid in(select tid from tableid);
这3条语句怎么把 select tid from tableid 给 抽取出来呢。 这样写效率会不会很低呢。
有什么好方法吗

使用游标,在DELETE和UPDATE的时候用LOOP循环,就能知道每一次的TID的值了;
或者直接写LOOP循环,把每一次的tid的值写在一个字符串里,用逗号分开,也得用cursor
参考技术A 可以用 EXISTS 来 替换掉 IN
例如:

delete from t1 where EXISTS ( SELECT * FROM tableid WHERE t1.tid = tableid.tid )
理论上说,速度会比用 IN 快一点。
参考技术B 可以用游标把tid字段循环出来!关键不知道你要实现的是什么,如果只是看语句的话没有什么问题!

oracle存储过程中执行查询sql语句报错

Create Or Replace Procedure UP_ExecSqlProcForDS(strSql In Varchar2,cur_out Out sys_refcursor)
As
Begin
Open cur_out For
Execute immediate strSql;
End;
strSql是一条查询sql语句,类似于select * from table,我想要的是给存储过程传一个查询的sql语句,然后存储过程给我返回结果集,怎么弄?

参考技术A 你这种可以用函数来实现
CREATE OR REPLACE FUNCTION UP_ExecSqlProcForDS RETURN NUMBER IS

CURSOR tmcur_out IS
select *from table
;
begin
FOR l_cur IN tmcur_out LOOP
end loop
exception
end
这个只是框架,你自己可以 根据自己的需要作适当修改
参考技术B Open cur_out For strsql;
这个是么?
这是定义游标的使用方法,游标的语法是一个SELECT语句的字符串

type cursor_type is ref cursor;
c1 cursor_type;

open c1 for selectsql;
参考技术C CREATE OR REPLACE Procedure UP_ExecSqlProcForDS(strSql In Varchar2,cur_out Out sys_refcursor)
As
Begin
Open cur_out For
strSql;
End;本回答被提问者采纳
参考技术D 我空间有个关于存储过程的,看看能不能帮到你。

以上是关于oracle 存储过程sql语句的主要内容,如果未能解决你的问题,请参考以下文章

怎样在sql语句中oracle调用存储过程

oracle SQL语句中怎么样调用存储过程

如何在oracle存储过程中执行动态sql语句

oracle带参数的存储过程,一直提示sql无效sql语句。求高手指点

Oracle [存储过程] 执行动态拼接SQL语句并返回结果??

plsql调用oracle存储过程有输入参数和输出参数 sql语句怎么写如题 谢谢了